事务的四个特性是什么,四种隔离级别分别能够解决并发事务中的哪些问题。
1. 事务的四个特性(ACID)
● 原子性(Atomicity):操作这些指令时,要么全部执行成功,要么全部不执行。只要其中一个指令执行失败,所有的指令都执行失败,数据进行回滚,回到执行指令前的数据状态。
● 一致性(Consistency):事务的执行使数据从一个状态转换为另一个状态,但是对于整个数据的完整性保持稳定。
1 | 拿转账来说,假设用户A和用户B两者的钱加起来一共是20000,那么不管A和B之间如何转账,转几次账, |
● 隔离性(Isolation):隔离性是当多个用户并发访问数据库时,比如操作同一张表时,数据库为每一个用户开启的事务,不能被其他事务的操作所干扰,多个并发事务之间要相互隔离。即要达到这么一种效果:对于任意两个并发的事务T1和T2,在事务T1看来,T2要么在T1开始之前就已经结束,要么在T1结束之后才开始,这样每个事务都感觉不到有其他事务在并发地执行。
● 持久性(Durability):当事务正确完成后,它对于数据的改变是永久性的。
1 | 例如我们在使用JDBC操作数据库时,在提交事务方法后,提示用户事务操作完成, |
2. 并发事务导致的问题
在许多事务处理同一个数据时,如果没有采取有效的隔离机制,那么并发处理数据时,会带来一些的问题。
脏读:脏读是指在一个事务处理过程里读取了另一个未提交的事务中的数据。
不可重复读:一个事务两次读取同一行的数据,结果得到不同状态的结果,中间正好另一个事务更新了该数据,两次结果相异。
幻读:一个事务执行两次查询,第二次结果集包含第一次中没有或某些行已经被删除的数据,造成两次结果不一致,只是另一个事务在这两次查询中间插入或删除了数据造成的。**幻读是事务非独立执行时发生的一种现象。
1 | 不可重复读的重点是修改: |
3. 隔离级别
Read uncommitted(最低级别,任何情况都无法保证。)
读未提交,顾名思义,就是一个事务可以读取另一个未提交事务的数据。
Read committed(可避免脏读的发生。)
读提交,顾名思义,就是一个事务要等另一个事务提交后才能读取数据。
Repeatable read(可避免脏读、不可重复读的发生。)
重复读,就是在开始读取数据(事务开启)时,不再允许修改操作
Serializable(可避免脏读、不可重复读、幻读的发生。) 序列化
Serializable 是最高的事务隔离级别,在该级别下,事务串行化顺序执行,可以避免脏读、不可重复读与幻读。但是这种事务隔离级别效率低下,比较耗数据库性能,一般不使用。
隔离级别 | 异常情况 | ||
---|---|---|---|
读未提交 | 脏读 | 不可重复读 | 幻读 |
读已提交 | 不可重复读 | 幻读 | |
可重复读 | 幻读 | ||
序列化 |
4. mysql事务测试
4.1 准备
1、打开mysql的命令行,将自动提交事务给关闭
1 | --查看是否是自动提交 1表示开启,0表示关闭 |
2、数据准备
1 | --创建数据库 |
4.2 测试脏读
1 | set session transaction isolation level read uncommitted; |
4.3 测试不可重复读
当使用read committed的时候,就不会出现脏读的情况了,但会出现不可重复读的问题
1 | A:start transaction; |
4.4 测试幻读
当使用repeatable read的时候,就不会出现不可重复读的问题,但是会出现幻读的问题。
1 | A:start transaction; |
Tips:
1 | 大多数数据库默认的事务隔离级别是Read committed,比如Sql Server , Oracle。Mysql的默认隔离级别是Repeatable read。 |
- 本文作者: zicair
- 本文链接: https://zicair.github.io/2020/08/29/mysql事务的隔离级别/
- 版权声明: 本博客所有文章除特别声明外,均采用 MIT 许可协议。转载请注明出处!