当前位置: 首页 > news >正文

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中的版本链查看数据的上一个版本是否可见,直到版本可见或者版本链到头。

http://www.dtcms.com/a/291993.html

相关文章:

  • 【时时三省】(C语言基础)指向函数的指针
  • SpringCloud Nacos配置中心
  • CentOS 8文件描述符耗尽检测与处理实战指南
  • Linux CentOS 虚拟机升级内核至4.x以上版本
  • 为何在 Vue 的 v-model 指令中不能使用可选链(Optional Chaining)?
  • AI-调查研究-35-咖啡价格战 味觉与消费体验差异:自制咖啡为何更“好喝”?
  • 【Practical Business English Oral Scene Interpretation】 No9~10
  • vue 用hbuilder打包apk后返回键不好使
  • importlib.import_module() 的用法与实战案例
  • 重构创作边界:川翔云电脑 - UE5云端超算引擎​
  • B端UI组件库重构:如何让开发效率提升40%的交互逻辑拆解
  • 拥抱区块链红利:机遇无限,风险暗涌
  • Python 绘制各类折线图全指南:从基础到进阶
  • MATLAB软件使用频繁,企业如何做到“少买多用”?
  • 互联网隐私的未来:Web3、区块链与神秘法宝
  • Function Modifier
  • 动漫短剧系统开发:构建下一代沉浸式娱乐平台的架构设计与技术突破
  • 使用qt编写上位机程序,出现串口死掉无法接受数据的bug
  • Kotlin 中的单例模式(Singleton)与对象声明
  • 力扣-链表相关题 持续更新中。。。。。。
  • 手写 防抖函数、节流函数
  • 【企业APP上架小米应用商店需要做的准备】(本示例为uniapp开发)
  • LLM评测框架Ragas:SQL指标(解决了Ollama推理框架不支持的问题)
  • oracle查询数据结构滤涉及的sql语句
  • 程序是如何生成的-以c语言为例
  • 行内元素垂直边距为何失效?
  • Vite:下一代前端构建工具的革命
  • 金仓数据库风云
  • 基于JAVA实现基于“obj--html--pdf” 的PDF格式文本生成
  • C语言第二章分支与循环(下)——猜数字游戏