当前位置:网站首页>绝对最直白的MySQL MVCC机制总结,免费拿走
绝对最直白的MySQL MVCC机制总结,免费拿走
2022-08-02 15:01:00 【InfoQ】
作者:知识浅谈,CSDN签约讲师,后端领域优质创作者,阿里云社区技术博主,热爱分享创作
擅长领域:全栈工程师、爬虫、ACM算法
公众号:知识浅谈
联系方式vx:zsqtcc
绝对最直白的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_ID
和
DB_ROLL_PTR
,
TRX_ID 是 此次修改的事务id,
DB_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会重新生成,导致产生幻读
总结
终于写完了,这个总结我是弄懂了之后才发出来的,仔细看图片中的每一句话,相信你会有所收获。
边栏推荐
- PAT甲级 1145 哈希 - 平均查找时间
- Eight big software attack overview of supply chain
- PostGresql listen与notify命令
- MySQL的简单运用-where、update、delete、like、union
- ShardingSphere基本介绍及核心概念
- 基于ip的证书
- 【Untitled】
- UnicodeEncodeError: 'gbk' codec can't encode character '\u2022' in position 178: illegal multibyte s
- Typora永久使用,彻底解决This beta version of Typora is expired.
- MySQL 自增主键
猜你喜欢
随机推荐
es6 循环,并终止循环
Qt | 设置部件大小 sizeHint、minimumSizeHint、sizePolicy、stretch factor
QT | VS2017 + Qt5.14.2 环境搭建
兆骑科创双创服务平台,创业赛事活动,投融资对接平台
DC-DC选型及电路设计
Qt | 模态对话框和非模态对话框 QDialog
Reading is the cheapest and noblest
Based on mobileNet dog breed classification (migration)
矩阵的特征值与特征向量
Traverse Heap PAT Class A 1155 Heap Path
CNN flower classification
阿里面试败北:5种微服务注册中心如何选型?这几个维度告诉你
中科驭数等单位牵头发布行业首部DPU评测方法技术白皮书
该死的单元测试,写起来到底有多痛?
Qt | Qt 的项目文件.pro 文件详解
【服务器数据恢复】Raid阵列更换故障硬盘后数据同步失败的数据恢复案例
5000mAh大电池!华为全新鸿蒙手机今晚亮相:更流畅更安全
Apache APISIX 2.15 版本发布,为插件增加更多灵活性
基于ip的证书
redis学习四redis消息订阅、pipeline、事务、modules、布隆过滤器、缓存LRU













