共计 6088 个字符,预计需要花费 16 分钟才能阅读完成。
自动写代码机器人,免费开通
这篇文章将为大家详细讲解有关 MySQL 和 JDBC 事务控制的示例分析,丸趣 TV 小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。
一、MySQL 的事务控制(Transaction Control Language)
(1)事务的特性(ACID)
事务指的是逻辑上的一组操作,组成这组操作的逻辑单元要么一起成功,要么一起失败。
原子性(atomicity):强调事务不可分割。
一致性(consistency):强调的是事务的执行的前后,数据的完整性要保持一直。
隔离性(isolation):一个事务的执行不应该受到其他事务的干扰。
持久性 (durability):事务一旦结束(提交 / 回滚) 数据就持久保持到了数据库。
(2)MySQL 的事务控制
设置手动提交:set autocommit = false;
回滚 rollback;
提交 commit ;
(3)mysql 事务演示
☆查看已经存在的 emp 表:
mysql select * from emp;+-------+--------+--------+------+------------+----------+--------+--------+| empno | ename | job | mgr | hiredate | sal | commit | deptno |+-------+--------+--------+------+------------+----------+--------+--------+| 1002 | 白展堂 | clerk | 1001 | 1983-05-09 | 7000.00 | 200.00 | 10 || 1003 | 李大嘴 | clerk | 1002 | 1980-07-08 | 8000.00 | 100.00 | 10 || 1004 | 吕秀才 | clerk | 1002 | 1985-11-12 | 4000.00 | NULL | 10 || 1005 | 郭芙蓉 | clerk | 1002 | 1985-03-04 | 4000.00 | NULL | 10 || 1007 | 小白 | clerk | 1001 | 2019-11-25 | 5555.00 | 500.00 | NULL || 2001 | 胡一菲 | leader | NULL | 1994-03-04 | 15000.00 | NULL | 20 || 2002 | 陈美嘉 | manger | 2001 | 1993-05-24 | 10000.00 | 300.00 | 20 || 2003 | 吕子乔 | clerk | 2002 | 1995-05-19 | 7300.00 | 100.00 | 20 || 2004 | 张伟 | clerk | 2002 | 1994-10-12 | 8000.00 | 500.00 | 20 || 2005 | 曾小贤 | clerk | 2002 | 1993-05-10 | 9000.00 | 700.00 | 20 || 3001 | 刘梅 | leader | NULL | 1968-08-08 | 13000.00 | NULL | 30 || 3002 | 夏冬梅 | manger | 3001 | 1968-09-21 | 10000.00 | 600.00 | 30 || 3003 | 夏雪 | clerk | 3002 | 1989-09-21 | 8000.00 | 300.00 | 30 || 3004 | 张一山 | clerk | 3002 | 1991-06-16 | 8000.00 | 200.00 | 30 || 3007 | 嫦娥 | clerk | NULL | NULL | NULL | NULL | 10 |+-------+--------+--------+------+------------+----------+--------+--------+15 rows in set (0.00 sec)
①设置手动提交:
mysql set autocommit=false;Query OK, 0 rows affected (0.03 sec)
②在 emp 表中插入一条 ename 为 mary 的语句:
mysql insert into emp(ename,job,commit)
- values(mary , clerk ,300);Query OK, 1 row affected (0.02 sec)mysql select * from emp;+-------+--------+--------+------+------------+----------+--------+--------+| empno | ename | job | mgr | hiredate | sal | commit | deptno |+-------+--------+--------+------+------------+----------+--------+--------+| 1002 | 白展堂 | clerk | 1001 | 1983-05-09 | 7000.00 | 200.00 | 10 || 1003 | 李大嘴 | clerk | 1002 | 1980-07-08 | 8000.00 | 100.00 | 10 || 1004 | 吕秀才 | clerk | 1002 | 1985-11-12 | 4000.00 | NULL | 10 || 1005 | 郭芙蓉 | clerk | 1002 | 1985-03-04 | 4000.00 | NULL | 10 || 1007 | 小白 | clerk | 1001 | 2019-11-25 | 5555.00 | 500.00 | NULL || 2001 | 胡一菲 | leader | NULL | 1994-03-04 | 15000.00 | NULL | 20 || 2002 | 陈美嘉 | manger | 2001 | 1993-05-24 | 10000.00 | 300.00 | 20 || 2003 | 吕子乔 | clerk | 2002 | 1995-05-19 | 7300.00 | 100.00 | 20 || 2004 | 张伟 | clerk | 2002 | 1994-10-12 | 8000.00 | 500.00 | 20 || 2005 | 曾小贤 | clerk | 2002 | 1993-05-10 | 9000.00 | 700.00 | 20 || 3001 | 刘梅 | leader | NULL | 1968-08-08 | 13000.00 | NULL | 30 || 3002 | 夏冬梅 | manger | 3001 | 1968-09-21 | 10000.00 | 600.00 | 30 || 3003 | 夏雪 | clerk | 3002 | 1989-09-21 | 8000.00 | 300.00 | 30 || 3004 | 张一山 | clerk | 3002 | 1991-06-16 | 8000.00 | 200.00 | 30 || 3007 | 嫦娥 | clerk | NULL | NULL | NULL | NULL | 10 || 4008 | mary | clerk | NULL | NULL | NULL | 300.00 | NULL |+-------+--------+--------+------+------------+----------+--------+--------+16 rows in set (0.00 sec)
③使用 rollback 回滚
mysql rollback;Query OK, 0 rows affected (0.00 sec)mysql select * from emp;+-------+--------+--------+------+------------+----------+--------+--------+| empno | ename | job | mgr | hiredate | sal | commit | deptno |+-------+--------+--------+------+------------+----------+--------+--------+| 1002 | 白展堂 | clerk | 1001 | 1983-05-09 | 7000.00 | 200.00 | 10 || 1003 | 李大嘴 | clerk | 1002 | 1980-07-08 | 8000.00 | 100.00 | 10 || 1004 | 吕秀才 | clerk | 1002 | 1985-11-12 | 4000.00 | NULL | 10 || 1005 | 郭芙蓉 | clerk | 1002 | 1985-03-04 | 4000.00 | NULL | 10 || 1007 | 小白 | clerk | 1001 | 2019-11-25 | 5555.00 | 500.00 | NULL || 2001 | 胡一菲 | leader | NULL | 1994-03-04 | 15000.00 | NULL | 20 || 2002 | 陈美嘉 | manger | 2001 | 1993-05-24 | 10000.00 | 300.00 | 20 || 2003 | 吕子乔 | clerk | 2002 | 1995-05-19 | 7300.00 | 100.00 | 20 || 2004 | 张伟 | clerk | 2002 | 1994-10-12 | 8000.00 | 500.00 | 20 || 2005 | 曾小贤 | clerk | 2002 | 1993-05-10 | 9000.00 | 700.00 | 20 || 3001 | 刘梅 | leader | NULL | 1968-08-08 | 13000.00 | NULL | 30 || 3002 | 夏冬梅 | manger | 3001 | 1968-09-21 | 10000.00 | 600.00 | 30 || 3003 | 夏雪 | clerk | 3002 | 1989-09-21 | 8000.00 | 300.00 | 30 || 3004 | 张一山 | clerk | 3002 | 1991-06-16 | 8000.00 | 200.00 | 30 || 3007 | 嫦娥 | clerk | NULL | NULL | NULL | NULL | 10 |+-------+--------+--------+------+------------+----------+--------+--------+15 rows in set (0.00 sec)
发现 mary 没有插入成功,因为手动提交后进行和回滚;如果使用 commit 进行提交就无法回滚成功,因为直接插入进数据库中了。
二、JDBC 的事务控制
(1)JDBC 事务简介
默认事务提交策略:一条命令自成一个完整事务。
需求:各个逻辑单元要么一起成功,要么一起失败。(如转账)
(2)JDBC 事务的 API
conn.setAutoCommit(false);// 将 JDBC 事务设置手动提交 conn.commit();conn.rollback();
(3)JDBC 事务控制模拟
在 emp 表中修改 ename 名为 hellen 的记录, 将其 job 从 leader 修改为 clerk, 奖金 commit 从 600 降低至 300。
(模拟交易)TrasactionDemo:
package jdbc;import java.sql.Connection;import java.sql.PreparedStatement;import java.sql.SQLException;import util.JdbcUtil;/**
* JDBC 事务控制
*
* @author Administrator
*
*/public class TestTrasaction {public static void main(String[] args) {
Connection conn = null;
PreparedStatement pstm = null;
PreparedStatement pstm1 = null;
try {
// 获得连接
conn = JdbcUtil.getConnection();
// 将 JDBC 事务设置手动提交
conn.setAutoCommit(false);
// ①降职操作
String sql = updata emp set job = clerk where ename = hellen
pstm = conn.prepareStatement(sql);
pstm.executeUpdate();
// ②降奖金操作
String sql1 = updata emp set commit= 3000 where ename = hellen
pstm1 = conn.prepareStatement(sql1);
pstm1.executeUpdate();
// 提交事务
conn.commit();} catch (Exception e) {
// 事务回滚
try {conn.rollback();
} catch (SQLException e1) {e1.printStackTrace();
} finally {
try {JdbcUtil.release(null, pstm, null);
JdbcUtil.release(null, pstm1, conn);
} catch (Exception e) {e.printStackTrace();
}}
代码中添加了 JDBC 事务来处理两条 sql 语句(一条正确, 一条错误),两条 sql 语句都没有执行。如果不添加 JDBC 事务处理,那么其中一条正确的 sql 语句就会单独执行。
关于“MySQL 和 JDBC 事务控制的示例分析”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。
向 AI 问一下细节