MySQL 学习二 MVCC

MVCC是多版本并发控制。目的是让读写能够并发。

是innodb通过undo log记录数据变更的版本信息实现的。

每个事务读到的版本是不一致的。同一个事务中,用户只能看到当前事务中创建的快照的内容(在事务开始之前就已经存在的数据),以及事务本身的操作。

MVCC的使用场景:在事务隔离级别读已提交和可重复读才会使用到。

读已提交:

可重复读:整个事务中,每次读取数据都用的是同一个read view。

1.MVCC的实现原理

三个方面:

1 隐藏字段

2 undo log

3 read view

2.隐藏字段

DB_TRX_ID 对数据进行新增或修改的最后一条事务id(删除视为修改)。事务id是递增的。

DB_ROLL_PTR 滚动指针,指向写入回滚段的撤销日志记录。Undo log中记录的多个版本之间用这个指针相连。

DB_ROW_ID 行id,如果表中没有主键,没有唯一非空索引。则mysql会自动将这个字段作为聚簇索引。(这个字段与MVCC实现相关不大)

3.Undo log的存储结构

场景:

当有一个事务要修改数据。

第一步:获取排他锁。

第二步:将当前数据行复制到undo log中,作为旧版本。

第三部:复制完之后,修改改数据,并且trx_id递增,并将roll_ptr指向undo_log中的旧版本。

4.Read view

Read view是读操作可见性(判断某个版本的数据是否对当前事务可见)判断的核心。Read view存储在内存中,不会写到磁盘上。

创建时机:在事务开启后第一个select开启,才会去创建read view。

在read view中可能会出现不应该被当前事务看到的其他活跃的事务列表。因为活跃的事务还没有提交,所以活跃的事务的数据,当前事务是不能看的。

当用户读取某一行数据时,会将数据的rtx_id与read view中的一些数据进行比较。

Read view中的关键数据:

m_creator_trx_id:创建该Read View的事务ID。

m_ids:创建Read View时系统中所有未提交的事务ID集合(活跃事务列表),不包含当前事务Id。

min_trx_id:m_ids中的最小事务ID,表示最早未提交的事务。

max_trx_id:创建Read View时系统将分配的下一个事务ID(即当前最大事务ID + 1)。

可见性规则:

若数据的DB_TRX_ID(记录最近修改的事务ID)等于m_creator_trx_id,说明是当前事务修改的,可见。

若DB_TRX_ID < min_trx_id,说明数据的当前版本在Read View创建前已提交(上一次造成数据修改的事务已经提交了),可见。

若DB_TRX_ID ≥ max_trx_id,说明数据的当前版本在Read View创建后生成(当前造成数据修改的事务实在read view生成之后开始的,而当前事务要读取的肯定是在造成数据修改事务之前的版本),不可见。

若min_trx_id ≤ DB_TRX_ID < max_trx_id:若DB_TRX_ID在m_ids中,说明该版本未提交,不可见。否则,说明该版本已提交,可见。

如果数据的当前版本不可见,那么沿着undo log中的版本链查看数据的上一个版本是否可见,直到版本可见或者版本链到头。

相关推荐
这是程序猿2 分钟前
mysql的安装教程
java·人工智能·windows·mysql
qq_206901393 分钟前
如何为 JSON 序列化中的不同浮点字段指定独立的小数精度
jvm·数据库·python
空中海6 分钟前
Redis 原理深度解析:持久化 × 主从复制 × Sentinel × Cluster × 性能排查全攻略
数据库·redis·sentinel
AI-小柒7 分钟前
磅上线!DataEyes 聚合平台正式接入 GPT-Image-2,开启多模态 AI 生成全新纪元
大数据·开发语言·数据库·人工智能·gpt·php
zhangrelay8 分钟前
Lubuntu 26.04移动系统使用配置测试记录与引导修复备注
笔记·学习
m0_588758489 分钟前
解决Navicat正向工程从模型建表报错怎么办_外键关联与语法解析
jvm·数据库·python
摇曳的精灵10 分钟前
OceanBase学习
学习·oceanbase
2501_9142459317 分钟前
如何修复宝塔面板由于inode耗尽导致无法创建文件_清理海量小文件缓存与会话目录
jvm·数据库·python
Gauss松鼠会17 分钟前
GaussDB for DWS 数据融合:Oracle数据迁移到GaussDB(DWS)
数据库·oracle·数据库开发·gaussdb
星幻元宇VR19 分钟前
VR消防安全学习机,数字化消防培训新选择
科技·学习·安全·vr