登录
首页 >  数据库 >  MySQL

MySQL 快照读:为什么 UPDATE 操作后 SELECT 会返回最新数据?

时间:2024-11-12 18:28:03 166浏览 收藏

小伙伴们有没有觉得学习数据库很有意思?有意思就对了!今天就给大家带来《MySQL 快照读:为什么 UPDATE 操作后 SELECT 会返回最新数据?》,以下内容将会涉及到,若是在学习中对其中部分知识点有疑问,或许看了本文就能帮到你!

MySQL 快照读:为什么 UPDATE 操作后 SELECT 会返回最新数据?

MySQL的快照读行为

在MySQL中,事务隔离的行为通过MVCC(多版本并发控制)机制实现,该机制确保同一数据不会被多个事务同时修改,从而导致数据不一致。在事务隔离级别为REPEATABLE READ的情况下,读取操作会返回开始事务时的数据快照,即其他事务的修改不会立即被读取到。

快照读与UPDATE的影响

但有例外情况,当一个事务执行了UPDATE操作后,后续的SELECT操作可能不会再返回快照数据。在这种情况下,MySQL会根据以下规则决定是否返回最新数据:

  1. 被修改的行ID必须大于事务的m_up_limit_id。
  2. 被修改的行ID必须小于或等于事务的m_low_limit_id。

案例分析

在给定的案例中,事务A执行了SELECT操作,没有查到ID为5的数据,因为该数据被事务B的UPDATE操作修改了。按照MVCC机制,事务A的后续SELECT操作应该仍然无法查到该数据,因为它介于m_up_limit_id(事务A的ID)和m_low_limit_id(事务B的ID加1)之间。

异常行为的原因

但实际上,事务A的第二次SELECT操作却查到了ID为5的数据,原因是满足了上述规则的第一条:被修改行的ID(5)大于事务A的m_up_limit_id(事务A的ID),因此MySQL返回了最新数据。

这表明在REPEATABLE READ隔离级别下,快照读并非在任何情况下都是完全一致的,当满足特定规则时,MySQL可能会返回最新数据,以保证数据更及时地可见。

到这里,我们也就讲完了《MySQL 快照读:为什么 UPDATE 操作后 SELECT 会返回最新数据?》的内容了。个人认为,基础知识的学习和巩固,是为了更好的将其运用到项目中,欢迎关注golang学习网公众号,带你了解更多关于的知识点!

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