💎一站式轻松地调用各大LLM模型接口,支持GPT4、智谱、星火、月之暗面及文生图 广告
``` mysql事务四大特征(acid): 1. 原子性 2. 一致性 3. 隔离性 4. 持久性 以下几个概念是事务隔离级别要实际解决的问题,所以需要搞清楚都是什么意思。 **脏读** 脏读指的是读到了其他事务未提交的数据,未提交意味着这些数据可能会回滚,也就是可能最终不会存到数据库中,也就是不存在的数据。读到了并一定最终存在的数据,这就是脏读。 个人理解:并发事务中读取到了并没有提交的事务修改后的数据,比如你读取张三年龄原本是10岁,在其他事务中正在修改张三年龄位20岁,修改后并没有提交事务,但是自己读取到的年龄却是20岁(被修改过的),这就是脏读。 **可重复读** 可重复读指的是在一个事务内,最开始读到的数据和事务结束前的任意时刻读到的同一批数据都是一致的。通常针对数据**更新(UPDATE)**操作。 **不可重复读** 对比可重复读,不可重复读指的是在同一事务内,不同的时刻读到的同一批数据可能是不一样的,可能会受到其他事务的影响,比如其他事务改了这批数据并提交了。通常针对数据**更新(UPDATE)**操作。 个人理解:在并发事务中读取了其他事务中修改或者删除过的数据,并且已经是提交了事务的。这样会导致你在事务1中读取的数据是不一致的。 **幻读** 幻读是针对数据**插入(INSERT)**操作来说的。假设事务A对某些行的内容作了更改,但是还未提交,此时事务B插入了与事务A更改前的记录相同的记录行,并且在事务A提交之前先提交了,而这时,在事务A中查询,会发现好像刚刚的更改对于某些数据未起作用,但其实是事务B刚插入进来的,让用户感觉很魔幻,感觉出现了幻觉,这就叫幻读。 个人理解:并发事务中针对其他事务添加操作并且提交了事务,比如自己在查询用户数量时上一秒查询 事务隔离级别: 1. 读未提交(READ UNCOMMITTED) 2. 读提交 (READ COMMITTED) 3. 可重复读 (REPEATABLE READ) 4. 串行化 (SERIALIZABLE) ``` ![](https://img.kancloud.cn/83/f4/83f486e66c8456654b385d468f2b31a6_387x224.png) ``` 从上往下,隔离强度逐渐增强,性能逐渐变差。采用哪种隔离级别要根据系统需求权衡决定,其中,**可重复读**是 MySQL 的默认级别。 事务隔离其实就是为了解决上面提到的脏读、不可重复读、幻读这几个问题,下面展示了 4 种隔离级别对这三个问题的解决程度。 MySQL 的 InnoDB 引擎才支持事务,其中可重复读是默认的隔离级别。 读未提交和串行化基本上是不需要考虑的隔离级别,前者不加锁限制,后者相当于单线程执行,效率太差。 读提交解决了脏读问题,行锁解决了并发更新的问题。并且 MySQL 在可重复读级别解决了幻读问题,是通过行锁和间隙锁的组合 Next-Key 锁实现的。 ```