https://xiaolincoding.com/mysql/transaction/mvcc.html#事务的隔离级别有哪些
- 对于「读未提交」隔离级别的事务来说,因为可以读到未提交事务修改的数据,所以直接读取最新的数据就好了。
- 对于「串行化」隔离级别的事务来说,通过加读写锁的方式来避免并发访问;
- 对于「读提交」和「可重复读」隔离级别的事务来说,它们是通过 Read view 来实现,它们的区别在于创建 Read View 的时机不同,大家可以把 Read View 理解成一个数据快照,就像相机拍照那样,定格某一时刻的风景。读提交隔离级别是在「每个语句执行前」都会生成一个 Read View ,而「可重复读」隔离级别是「启动事务时」生成一个 Read View,然后整个事务期间都在用这个 Read View。
注意,执行「开始事务」命令,并不意味着启动了事务。在 MySQL 有两种开启事务的命令,分别是:
- 第一种:begin/start transaction 命令;
- 第二种:start transaction with consistent snapshot 命令;
这两种开启事务的命令,事务的启动时机是不同的:
- 执行了 begin/start transaction 命令后,并不代表事务启动了。只有在执行这个命令后,执行了第一条 select 语句,才是事务真正启动的时机;
- 执行了 start transaction with consistent snapshot 命令,就会马上启动事务。
接下来详细说下,Read View 在 MVCC 里如何工作的?