Mysql MVCC

MVCC多版本并发控制本质就是每个事务读到的不是同一个正在被修改的数据,而是自己对应的历史版本快照。所以多个事务既然同时读又能同时写,读写互不阻塞,这就是数据库高并发的秘密武器。那历史版本怎么来的,是通过undo log ,数据库中只存了最新的一条记录,然后通过undo log记录反向操作(如insert一条数据,就在undo log中delete一条数据,update一条数据就在undo log留旧值),所以需要老版本时只要顺着这些日志往回找就可以,所以一条记录和undo log就串成了一条版本链。

那么当前事务可以看到版本链的哪一条呢?这就要通过ReadView,它会记录哪些事务已经提交,哪些还活跃,然后按照一套规则决定这个版本你能不能看。(具体就是自己改的永远能看,比自己再提交的能看,还没提交的不能看)

在不同隔离级别下的区别:读已提交每次查询都会重新生成一个ReadView,所以前后两次select的结果可能不一样就,也就是不可重复读;而可重复读只在第一次查询时生成ReadView后面一直直接用这个快照,所以整个事务多次查询结果保持一致,这就是可重复读。

总结,MVCC的核心是快照读,Undo log是历史版本的支撑,ReadView决定谁能看那个版本

相关推荐
NineData5 小时前
NineData智能数据管理平台新功能发布|2026年1-2月
数据库·sql·数据分析
IvorySQL6 小时前
双星闪耀温哥华:IvorySQL 社区两项议题入选 PGConf.dev 2026
数据库·postgresql·开源
ma_king9 小时前
入门 java 和 数据库
java·数据库·后端
jiayou6412 小时前
KingbaseES 实战:审计追踪配置与运维实践
数据库
随风飘的云13 小时前
mysql的innodb引擎对可重复读做了那些优化,可以避免幻读
mysql
NineData1 天前
NineData 迁移评估功能正式上线
数据库·dba
NineData1 天前
数据库迁移总踩坑?用 NineData 迁移评估,提前识别所有兼容性风险
数据库·程序员·云计算
赵渝强老师1 天前
【赵渝强老师】PostgreSQL中表的碎片
数据库·postgresql
全栈老石1 天前
拆解低代码引擎核心:元数据驱动的"万能表"架构
数据库·低代码
倔强的石头_2 天前
kingbase备份与恢复实战(二)—— sys_dump库级逻辑备份与恢复(Windows详细步骤)
数据库