对MVCC的理解

文章目录

MVCC即Mutil-Version Concurrency Control(多版本并发控制),用于保证并发快照读下的读已提交级别和可重复读级别。

快照读和当前读

1.快照读 :即普通的select语句

例如:select * from student

2.当前读

insert update delete

select ... for update

select ...lock in share mode

基于ubdo_log(回滚日志)的版本链

在每一行数据里有两个隐藏字段 :

1.trx_id 当前事务id

2.db_roll_ptr 指向上一个版本的指针

readview

readview是快照读时,提取哪一个数据版本的依据

  • m_ids :当前未提交的事务编号集合
  • min_trx_id:未提交的事务的集合里最小的事务编号
  • max_trx_id:预分配事务编号
  • creator_trx_id:创建者的事务编号

将每个版本的数据的事务id依次代入到判断规则当中来决定选取哪个版本的数据

判断规则:

1.首先判断数据的事务id和readview的制造事务id是否相等,等于则读取成功,不等于进入下一步

2.判断数据的事务id是否小于最小的未提交的事务的id,小于则表明这个数据已被提交,可以被访问,

3.判断数据的事务id是否大于预分配事务id,如果大于则表明这个数据还没提交,不可以访问

4.判断数据的事务id是否在未提交的事务集合里,如果不在,则表明已经提交,可以访问

5.若最终判断出这个数据不可以被访问,则通过指针找到上一个版本的数据,进行循环判断

在读已提交级别,每进行一次快照读都会生成一个readview,

在可重复读级别,每进行一次快照读都是同一个readview,以此来保证在同一个事务中,快照读到的数据是一致

在不可重复读的级别下,innodb不仅可以避免不可重复读,还可以避免幻读(不能完全避免)。

但是注意: 在两次快照读之中加入当前读会造成幻读

相关推荐
砚边数影1 天前
逻辑回归实战(二):Java + DL4J 实现模型,评估指标(准确率/召回率)计算
java·数据库·算法·机器学习·逻辑回归·金仓数据库
Cher ~1 天前
【数据结构】hash表(unordered_map)
java·数据结构·c++·算法·哈希算法
zfj3211 天前
好书分享:《两周自制脚本语言》-用java实现一个脚本语言
java·开发语言·python·编译原理
u0109272711 天前
自定义类型转换机制
开发语言·c++·算法
爱吃生蚝的于勒1 天前
【Linux】进程信号的产生(一)
linux·运维·服务器·c语言·开发语言·数据结构·c++
写代码的【黑咖啡】1 天前
Python中Excel文件的强大处理工具:OpenPyXL
开发语言·python·excel
索荣荣1 天前
Java反射:从入门到实战的终极指南
java·开发语言
全栈软件开发1 天前
php图形验证码生成系统源码 支持api接口调用 提供SDK 轻量级简单易用
开发语言·php
2401_838472511 天前
自定义操作符重载指南
开发语言·c++·算法
Leo655351 天前
easyExcel 的动态列导出把文本转为数值格式,可以进行函数计算
java