事务:是一组操作的集合,它是一个不可分割的工作单位,事务会把所有的操作作为一个整体一起向系统提交或撤销操作请求,即这些操作要么同时成功,要么都失败。
案例:
1.事务操作
(1)未控制事务
1)测试正常情况
2)测试异常情况
(2)控制事务一
1)查看/设置事务提交方式
SELECT @@autocommit;
SET @autocommit = 0;
2)提交事务
COMMIT;
3)回滚事务
ROLLBACK;
注:上述的这种方式,我们是修改了事务的自动提交行为,把默认的自动提交修改为了手动提交,此时我们执行的DML语句都不会提交,需要手动的执行COMMIT进行提交。
(3)控制事务二
1)开启事务
START TRANSACTION ;或BEGIN;
2)提交事务
COMMIT;
3)回滚事务
ROLLBACK;
案例:
2.事务的四大特性
- 原子性(Atomicity):事务是不可分割的最小操作单元,要么全部成功,要么全部失败。
- 一致性(Consistency):事务完成时,必须使所有的数据都保持一致状态。
- 隔离性(Isolation):数据库系统提供的隔离机制,保证事务在不受外部并发操作影响的独立环境下运行。
- 持久性(Durability):事务一旦提交或回滚,它对数据库中的数据的改变就是永久的。
上述就是事务的四大特性,简称ACID。
3.并发事务问题
(1)脏读:一个事务读到另外一个事务还没提交的数据。
比如B读取了A未提交的数据。
(2)不可重复读:一个事务先后读取同一条记录,但两次读取的数据不同,称之为不可重复读。
事务A两次读取同一条记录,但是读取到的数据却是不一样的。
(3)幻读:一个事务按照条件查询数据时,没有对应的数据行,但是在插入数据时,又发现这行数据已经存在,好像出现了“幻影”。
4.事务隔离级别
为了解决并发事务所引发的问题,在数据库中引入了事务隔离级别。主要有以下几种:
隔离级别 | 脏读 | 不可重复读 | 幻读 |
Read uncommitted | √ | √ | √ |
Read committed | × | √ | √ |
Repeatable Read(默认) | × | × | √ |
Serializable | × | × | × |
- √ 表示在当前隔离级别下该问题会出现
- Serializable 性能最低;Read uncommitted 性能最高,数据安全性最差
(1)查看事务隔离级别
SELECT @@TRANSACTION_ISOLATION;
(2)设置事务隔离级别
SET [ SESSION | GLOBAL ] TRANSACTION ISOLATION LEVEL { READ UNCOMMITTED | READ COMMITTED | REPEATABLE READ | SERIALIZABLE }
SESSION 是会话级别,表示只针对当前会话有效,GLOBAL 表示对所有会话有效
注:事务隔离级别越高,数据越安全,但是性能越低。