浅述当前模式读与一致性读续

在上一篇《浅述当前模式读与一致性读的区别》文章里,我用2个特殊例子描述当前模式读和一致性读之间的区别,并提到了“如在事务启动后到数据块被读取之间的这段时间内,相应的数据块发生了改变,那么可能就会有我们意想不到的事情发生”。而这样的意想不到的结果可能能被我们接受,但也可能难以被接受。

我们先看一下以下2条UPDATE语句:

  1. 1:    
  2. update t_test1 set lio=0 where object_id in (101,102);    
  3. 2:    
  4. update t_test1 set lio=(select lio from t_test1 where object_id = 101) where object_id = 102 and (select count(*) from t_test2 t1, t_test2 t2) > 0;   

从逻辑角度来说,无论运行了那条语句,我们希望两条记录(object_id=101和object_id=102)的lio都相同。

然而,由于UPDATE语句会同时引入一致性读和当前模式读,并且由于这两种读之间存在时间差,我们可能会得到不希望出现的结果。

这里我们演示一个例子。

  1. 13:27:23 HELLODBA.COM>update t_test1 set lio=1 where object_id in (101,102);    
  2.     
  3. rows updated.    
  4.     
  5. 13:29:06 HELLODBA.COM>commit;    
  6.     
  7. Commit complete.    
  8.     
  9. Session 1:    
  10. 13:29:06 HELLODBA.COM>alter system flush buffer_cache;    
  11.     
  12. System altered.    
  13.    
  14. 13:29:11 HELLODBA.COM>-- Transaction 1 begin ---    
  15. 13:29:11 HELLODBA.COM>update t_test1 set lio=(select lio from t_test1 where object_id = 101) where object_id = 102 and (select count(*) from t_test2 t1, t_test2 t2) > 0;    
  16.     
  17. 1 row updated.    
  18.     
  19. 13:29:25 HELLODBA.COM>commit;    
  20.     
  21. Commit complete.    
  22.     
  23. 13:29:25 HELLODBA.COM>-- Transaction 1 end ---    
  24. 13:29:25 HELLODBA.COM>select object_id, lio from t_test1 t where object_id in (101,102);    
  25.     
  26. OBJECT_ID        LIO    
  27. ---------- ----------    
  28.        101          0    
  29.        102          1    
  30.     
  31. 13:29:25 HELLODBA.COM>    
  32.     
  33. Session 2:    
  34.     
  35. 13:29:11 HELLODBA.COM>-- Transaction 2 begin ---    
  36. 13:29:16 HELLODBA.COM>update t_test1 set lio=0 where object_id in (101,102);    
  37.     
  38. rows updated.    
  39.     
  40. 13:29:16 HELLODBA.COM>commit;    
  41.     
  42. Commit complete.    
  43.     
  44. 13:29:16 HELLODBA.COM>-- Transaction 2 end ---   

在这个例子中,我们并发执行了上面两条语句,但最终得到一个和我们逻辑目标相左的结果。

事务1的SCN早于事务2的SCN,因此它用了一个快照数据(由一致性读得到的老的数据)来更新了当前数据(由当前模式读得到的最新的数据)。

我不能说这算不算MVCC的一个缺陷,但它最少已经造成了逻辑混乱。

 

【编辑推荐】

  1. 浅述当前模式读与一致性读的区别
  2. 告诉你,如何成就DBA职业生涯
  3. DBA应用技巧:如何升级InnoDB Plugin
  4. DBA必备:MySQL数据库常用操作和技巧
  5. MySQL日志操作教程:DBA们管理的利器

 

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/232215.html<

(0)
运维的头像运维
上一篇2025-04-20 01:45
下一篇 2025-04-20 01:46

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注