关于MySQL的幻读问题,看这一篇就够了

什么是幻读?

幻读指的是一个事务在前后两次查询同一个范围的时候,后一次查询看到了前一次查询没有看到的行。

首先快照读是不存在幻读的,只有当前读(实时读)才存在幻读的问题。

幻读有什么问题?

select ...for update语句就是将相应的数据行锁住,但是如果存在幻读,就把for update的语义破坏了。

如何解决幻读?

产生幻读的原因是,行锁只能锁住行,但是新插入记录这个动作,要更新的是记录之间的“间隙”。因此,为了解决幻读问题,InnoDB只好引入新的锁,也就是间隙锁(Gap Lock)。间隙锁和行锁合称next-key lock每个next-key lock是前开后闭区间

总结

  1. RR(可重复读)隔离级别下间隙锁才有效,RC(提交读)隔离级别下没有间隙锁;
  2. RR隔离级别下为了解决“幻读”问题:“快照读”依靠MVCC控制,“当前读”通过间隙锁解决;
  3. 间隙锁和行锁合称next-key lock,每个next-key lock是前开后闭区间;
  4. 间隙锁的引入,可能会导致同样语句锁住更大的范围,影响并发度。

版权声明:本文为Javaesandyou原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。