MySQL MVCC下update后select为什么还能读到数据?

mysql mvcc下update后select为什么还能读到数据?

MySQL中MVVC机制下update之后select快照读现象

MySQL中,事务隔离级别为READ COMMITTED时,使用多版本并发控制(MVVC)机制来实现快照读。

MVVC机制通过维护每个查询的可见快照点(SCN),并利用系统版本表(redo log)来实现,保证每个事务都可以访问查询开始时数据库的一致性视图。

当事务A执行update语句修改一行数据后,该行数据的SCN值会增加。如果随后另一个事务B执行select语句查询该行数据,则会使用该行数据的SCN值与其可见快照点进行比较,以确定是否可见。

根据MVVC机制的匹配规则,当行数据的SCN值介于事务B的SCN值(m_low_limit_id)和上限SCN值(m_up_limit_id)之间的,则该行数据对于事务B是不可见的。

然而,在某些情况下,满足第一条匹配规则时,update后select仍然能够查询到数据。该规则如下:

  • 如果行数据的SCN值大于等于事务B的m_up_limit_id,并且行数据的update语句属于事务B自身,则该行数据对于事务B是可见的。

因此,在问题中,事务A执行update语句后,id=5的数据的SCN值增加了。第二次 select 时,虽然该数据仍然介于事务A和B的SCN值之间,但由于该数据是由事务A自身更新的(属于事务A),因此满足了第一条匹配规则,所以事务B能够查看到该数据。

以上就是MySQL MVCC下update后select为什么还能读到数据?的详细内容,更多请关注其它相关文章!