绝对最直白的MySQL MVCC机制总结,免费拿走

本文深入浅出地介绍了MySQL InnoDB存储引擎下的MVCC(多版本并发控制)机制,通过实例分析了RC(读已提交)和RR(可重复读)级别下事务的执行情况,解释了ReadView、UNDO_LOG版本链以及它们如何影响查询结果。文章还探讨了MVCC如何防止幻读,并提供了总结和关键知识点。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在这里插入图片描述

🍁 作者:知识浅谈,CSDN签约讲师,后端领域优质创作者,阿里云社区技术博主,热爱分享创作
💒 公众号:知识浅谈
📌 擅长领域:全栈工程师、爬虫、ACM算法

绝对最直白的MySQL MVCC机制总结
🤞开胃小菜🤞

  • 在小ySQL InnoDB存储擎下RC(读已提交,RR(可重复读)基于MVCC(多版本并发控制)进行并发事务控制
  • MVCC是基于”数据版本”对并发事务进行访问。

🎈举例子引题

事务集合:
事务A:设置id=1088的name为张三
事务B:设置id=1088的name为张小三
事务C:设置id=1088的name为张老三
事务D:两次查询id=1088的名字
在这里插入图片描述
前三个事务分别进行了修改的操作,最后一个事务只有查询的操作。
RR级别:事务D的第一条Select查询结果为张三,第二条查询结果也为张三。
RC级别: 事务D的第一条Select查询结果为张三,第二条查询结果也为张小三。
因为RC级别下不可重复读,所以两次结果不一样,具体原因看到后边就懂了,先提一下,主要是因为RR级别只生成一个ReadView(快照)

🎈UNDO_LOG版本链

undolog就是undolog日志。
基于UNDO_LOG版本链如下:
在这里插入图片描述
版本链解析:在原来的字段基础上加上TRX_IDDB_ROLL_PTRTRX_ID 是 此次修改的事务idDB_ROLL_PTR是指向上一个修改的版本指针
🏹注意点
UNDO LOG不是会被删除吗❓
中间数据万一被删了版本链不就断了❓
答:

  • UNDO LOG版本链不是立即删除,
  • MySQL确保版本链数据不再被“引用”后再进行删除。

🎈ReadView是啥

上边给大家留了一个问题,Readview是什么,我们来看看

📙ReadView是“快照读”SQL执行时MVCC提取数据的依据。

  • 快照读就是最普通的Selecti查询SQL语句
  • 当前读指代执行下列语句时进行数据读取的方式,如Insert、.Update、Delete、Select…for update、Select…lock in share mode

📙ReadView,是一个数据结构,包含4个字段

  • mids:当前活跃的事务编号集合
  • min_trx_id:最小活跃事务编号
  • max_trx_id:预分配事务编号,当前最大事务编号+1
  • creator trx id:ReadView创建者的事务编号

🍮RC与ReadView的关系

RC(读已提交):在每一次执行快照读的时候都会生成一个新的ReadView

结合上边的例子来理解

  • RC与ReadView在这里插入图片描述
  • 拿第一次的来分析,结合右边的规则和ReadView对版本链进行从上到下比对,选择合适的版本取出对应的值即可。
    在这里插入图片描述
  • 拿第二次select的来分析,结合右边的规则和ReadView对版本链进行从上到下比对,选择合适的版本取出对应的值即可。
    在这里插入图片描述

🍮RC与ReadView的关系

RR(可重复读):仅仅在第一次执行快照读的时候生成ReadView,后续快照读服用之前生成的。(有例外:就是两次快照读中间有当前读的时候,就不会有两次快照读的ReadView就不一样了)

结合上边的例子来理解
在这里插入图片描述
RR级别下使用MVCC能避免幻读吗❓
答:能,但不完全能!
为何能🥕

  • 连续多次快照读,ReadView会产生复用,没有幻读问题
  • 特例:当两次快照读之间存在当前读,ReadView会重新生成,导致产生幻读
    在这里插入图片描述
    测试图
    在这里插入图片描述

🍚总结

终于写完了,这个总结我是弄懂了之后才发出来的,仔细看图片中的每一句话,相信你会有所收获。
Written By 知识浅谈Pro资源网

评论 9
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

知识浅谈

您的支持将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值