说下对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一致的可见外,其余不可见。

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

相关推荐
NetX行者3 小时前
.NET 9 GUID v7 vs v4:时间有序性如何颠覆数据库索引性能
数据库·mysql·abp vnext
sunon_3 小时前
实现druid数据源密码加密
数据库
sevevty-seven4 小时前
Redis中的红锁
数据库·redis·php
GoodStudyAndDayDayUp6 小时前
dbever 导出数据库表的建表语句和数据插入语句
数据库
没有口袋啦7 小时前
《Reids》配置文件
数据库·redis
诺亚凹凸曼7 小时前
浅谈mysql的undolog
数据库·mysql
m0_694845577 小时前
云服务器如何管理数据库(MySQL/MongoDB)?
服务器·数据库·mysql
devops_sre8 小时前
mongodb原理及其实现
数据库·mongodb
技术吧8 小时前
MySQL功能模块探秘:数据库世界的奇妙之旅
数据库·mysql