就MySQL中的RR(Repeatable Reads)事务隔离级别,到底有没有解决幻读问题发起了激烈的讨论。
一部分人说有,一部分人说没有。
结论,MySQL中的RR事务隔离级别,在特定的情况下会出现幻读的问题。
所谓的幻读,表示在同一个事务中的两次相同条件的查询得到的数据条数不一样。
那在RR级别下,具体什么情况下会出现幻读呢?
来看这样一种情况{如图},在事务1里面通过update语句触发当前读的情况下,就会导致在该事务中的前后两次查询的数据行数不一致,从而出现幻读的现象。
导致幻读的根本原因是,触发的当前读操作,绕过了快照读,从而导致MVCC机制在当前场景下失效。
最终读取到了事务2中已经提交的数据。
为了避免出现这类的情况,我们可以通过for update语句加锁。