登录
首页 >  数据库 >  MySQL

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

时间:2024-11-17 10:04:02 335浏览 收藏

怎么入门数据库编程?需要学习哪些知识点?这是新手们刚接触编程时常见的问题;下面golang学习网就来给大家整理分享一些知识点,希望能够给初学者一些帮助。本篇文章就来介绍《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能够查看到该数据。

今天带大家了解了的相关知识,希望对你有所帮助;关于数据库的技术知识我们会一点点深入介绍,欢迎大家关注golang学习网公众号,一起学习编程~

相关阅读
更多>
最新阅读
更多>
课程推荐
更多>