MySQL问题:MVCC是什么?

MVCC(多版本并发控制)是一种数据库并发控制技术,核心思想是通过维护数据的多个版本来实现高效的读写并发

MVCC工作原理:

数据版本链(事务ID和回滚指针链接成版本链)

ReadView(读视图)

ReadView中有四个字段,分别是:

m_ids:当前数据库中"活跃事务"(即启动了但没提交的事务)的事务id列表

min_trx_id:当前数据库中"活跃事务"中事务id最小的事务

Max_trx_id:当前数据库中应该给下一个事务的id值

Creator_trx_id:创建该ReadView的事务的事务id

除了这四个字段还要注意两个隐藏列在主键索引记录中

Trx_id:当事务对某条主键索引记录改动时,把该事务的事务id记录在这个列中

Roll_pointer:当事务对某条主键索引记录改动时,会把旧版本的记录写入undo日志中,这个隐藏列是个指针,指向每个旧版本记录

一个事务去访问记录的时候,除了自己的更新记录总是可见外,还有这几种情况:

1.如果trx_id<min_trx_id,代表这个记录是在创建ReadView前就提交的事务生成的,所以该版本的记录对当前事务可见。

2.trx_id>=max_trx_id,代表是创建ReadView后才启动的事务生成的,所以该版本的记录对当前事务不可见。

3.min_trx_id<trx_id<max_trx_id,也就是在之间,当trx_id在m_ids中不可见,不在则可见。

相关推荐
烟雨归来19 分钟前
升级openssh后ORACLE RAC EM 安装失败处理
数据库·oracle
TDengine (老段)23 分钟前
TDengine IDMP 应用场景:电动汽车
大数据·数据库·物联网·ai·时序数据库·iot·tdengine
BD_Marathon6 小时前
【Flink】部署模式
java·数据库·flink
csudata7 小时前
十年磨一剑,中启乘数CData数据库一体机重新定义企业级数据库解决方案
数据库·数据库开发
TDengine (老段)8 小时前
TDengine IDMP 应用场景:工业锅炉监控
大数据·数据库·物联网·信息可视化·时序数据库·tdengine
dreams_dream10 小时前
Django的Settings 配置文件详解
数据库·django·sqlite
遇见你的雩风11 小时前
【MySQL】CRUD基础详解
数据库·mysql
夜雨听萧瑟13 小时前
sqlite创建数据库,创建表,插入数据,查询数据的C++ demo
数据库·sqlite
.Shu.13 小时前
Mysql InnoDB 底层架构设计、功能、原理、源码系列合集【四、事务引擎核心 - MVCC与锁机制】
数据库·mysql
多工坊14 小时前
【DataGrip】连接达梦数据库后,能查询数据但是看不到表的几种情况分析,达梦数据库驱动包下载DmJdbcDriver18.jar
java·数据库·jar