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中不可见,不在则可见。

相关推荐
数据知道8 分钟前
PostgreSQL 核心原理:如何利用多核 CPU 加速大数据量扫描(并行查询)
数据库·postgresql
麦聪聊数据1 小时前
Web 原生架构如何重塑企业级数据库协作流?
数据库·sql·低代码·架构
未来之窗软件服务1 小时前
数据库优化提速(四)新加坡房产系统开发数据库表结构—仙盟创梦IDE
数据库·数据库优化·计算机软考
Goat恶霸詹姆斯3 小时前
mysql常用语句
数据库·mysql·oracle
大模型玩家七七3 小时前
梯度累积真的省显存吗?它换走的是什么成本
java·javascript·数据库·人工智能·深度学习
曾经的三心草3 小时前
redis-9-哨兵
数据库·redis·bootstrap
明哥说编程3 小时前
Dataverse自定义表查询优化:D365集成大数据量提速实战【索引配置】
数据库·查询优化·dataverse·dataverse自定义表·索引配置·d365集成·大数据量提速
xiaowu0803 小时前
C# 拆解 “显式接口实现 + 子类强类型扩展” 的设计思想
数据库·oracle
讯方洋哥4 小时前
HarmonyOS App开发——关系型数据库应用App开发
数据库·harmonyos
惊讶的猫4 小时前
Redis持久化介绍
数据库·redis·缓存