✅当前读和快照读有什么区别?
所谓快照读,就是读取的是快照数据,即快照生成的那一刻的数据,像我们**常用的普通的SELECT语句在不加锁情况下就是快照读。**如:
SELECT * FROM xx_table WHERE ...和快照读相对应的另外一个概念叫做当前读,当前读就是读取最新数据,所以**,加锁的 SELECT,或者对数据进行增删改都会进行当前读**,比如:
SELECT * FROM xx_table LOCK IN SHARE MODE;
SELECT * FROM xx_table FOR UPDATE;
INSERT INTO xx_table ...
DELETE FROM xx_table ...
UPDATE xx_table ...在MySQL 中,只有READ COMMITTED 和 REPEATABLE READ这两种事务隔离级别才会使用快照读。
- 在 RR 中,快照会在事务开始时生成,只有在本事务中对数据进行更改才会更新快照。
- 在 RC 中,每次读取都会重新生成一个快照,总是读取行的最新版本。