说下对mysql MVCC的理解

我们知道,mysql innodb存储引擎关于事务的默认隔离级别是RR,亦即可重复读。

而MVCC则是RR能够实现可重复读的保证,同时也是RC实现读已提交的保证。

我们先看下MVCC的原英与翻译:multi version concurrent control 多版本并发控制。

我就这个翻译来说道MVCC。它这里的多版本是啥意思?

首先,实现MVCC离不开:undoLog与readView。

undoLog我们应该都知道,存放的是事务更新日志记录,以备事务失败的回滚。

然后我们要知道,mysql每行记录,都有隐藏的db_trx_id(事务id),db_roll_point(回滚到undoLog的id),如果该行没主键则还会有个隐藏主键字段。

readView作为读视图,存放查询那一刻读视图快照,与行记录的trx_id做比较,小于readView的trx_id则记录可见,大于等于readView的trx_id的除了与readView的creator_trx_id一致的可见外,其余不可见。

依赖这两点,可以做到在并发读写事务的时候,既保证数据的安全性,又保证一定的性能。配合锁更可以保证可重复读的同时避免大部份幻读

相关推荐
类似不类似41 分钟前
mysql实例是什么?
数据库·mysql·adb
Johny_Zhao1 小时前
达梦数据库高可用集群部署方案
linux·mysql·网络安全·docker·信息安全·kubernetes·云计算·shell·containerd·达梦数据库·yum源·系统运维·centos8
hui函数1 小时前
订单后台管理系统-day07菜品模块
数据库·后端·python·flask
瓯雅爱分享1 小时前
Java搭建高效后端,Vue打造友好前端,联合构建电子采购管理系统,实现采购流程电子化、自动化,涵盖采购全周期管理,功能完备,附详细可运行源码
java·mysql·vue·软件工程·源代码管理
知彼解己1 小时前
数据库事务隔离级别与 MVCC 机制详解
数据库
阿里云大数据AI技术2 小时前
阿里云携手MiniMax构建云原生数仓最佳实践:大模型时代的 Data + AI 数据处理平台
大数据·数据库
小蒜学长2 小时前
vue飞自在酒店管理系统(代码+数据库+LW)
java·数据库·spring boot·后端
conkl2 小时前
MySQL 事务隔离与 MVCC
数据库·mysql
-Xie-2 小时前
Mysql杂志(七)
数据库·mysql
白鲸开源3 小时前
SeaTunnel 如何给 MySQL 表做“精准切片”?一篇读懂 CDC 分片黑科技
大数据·mysql·开源