首先要知道什么是幻读。
幻读指的是一个事务在前后两次查询同一个范围的时候,后一次查询看到了前一次没有看到的行。
比如下图的3个session 中
T1,T3,T5 查询的结果都不一样。
T3 属于不可重复读。
T5 就是幻读 因为T4刚插入了 一条数据
我们把数据库调成REPEATABLE READ重复读在执行一次会出现如下
由于 session A 把所有的行都加了写锁,所以 sessionB 在执行第一个update 语句的时候就锁住了,需要T6时刻提交后sessionB才能执行.所以T3 属于不可重复读 的问题解决了。
但是T5的幻读还存在,因为在T3时刻我们给所有的行都加了锁,但是新插入的行不存在,所以没发加锁。
也就是说,即使把所有记录都加上锁,也无法阻止新插入的记录。
这就是为什么mysql行锁解决方案无法阻止幻读。