MVCC简记

MVCC属于数据库事务中的技术,通过MVCC可以在无锁情况(死锁会减少)下实现mysql的可重复读与读已提交两种事务隔离级别。请先阅读事务博客

MVCC:多版本并发控制,控制事务能看到哪些版本的数据,哪些看不到。MVCC采用undolog链存储历史数据,每条记录有两个隐藏列id和undolog指针字段,每次查询生成readview,readview记录相对于该事务未提交的数据,通过readview与undolog比较,可以判断哪些数据是当前事务可见的。

  • 隐藏字段:聚簇索引行记录有trx_id,roll_pointer。
  • undo log 版本链:对未提交事务的数据并发修改会把历史记录存到undo log版本链,通过指针可以查到历史数据。事务提交后该undo log 会被回收。
  • Read View:使用四个字段记录当前事务的事务状态,判断哪些字段是否可以读取?哪些字段对于当前事务不可见?可以读取的字段的哪些历史版本可以读取?实现不同事务的隔离(只在下面两个级别工作)四个字段分别是:活跃事务aid,活跃事务中最小mid,下一事务nextid。undolog的id小于mid可见。大于nextid不可见。mid和nextid之间若在aid中不可见,否则可见
    • 可重复读隔离级别:开启事务后,执行第一条select语句,会创建read view,后面会 复用这个read view
    • 读已提交隔离级别:开启事务后,每执行一次select都会重新创建read view
    • 自己的更新记录是可见的
      • 如果记录的trx_id < read view 的min_trx_id,认为该记录已经被提交,事务可见。
      • 相反>= max_trx_id则未提交则不可见。
      • 如果max_trx_id > trx > min_trx_id,且在m_ids列表中则认为未提交不可见,不在m_ids列表中则可见
    • 可重复读没完全解决不可重复读 。快照读 (普通 select 语句),是通过 MVCC 方式解决了幻读。当前读 (select ... for update 等语句),是通过 next-key lock(记录锁+间隙锁)方式解决了幻读。快照读后再当前读会发生幻读,尽量在开启事务之后,马上执行 select ... for update 这类当前读的语句
相关推荐
ZTLJQ8 分钟前
数据的基石:Python中关系型数据库完全解析
开发语言·数据库·python
升鲜宝供应链及收银系统源代码服务43 分钟前
《IntelliJ + Claude Code + Gemini + ChatGPT 实战配置手册升鲜宝》
java·前端·数据库·chatgpt·供应链系统·生鲜配送
跟着珅聪学java1 小时前
js编写中文转unicode 教程
前端·javascript·数据库
小江的记录本1 小时前
【Redis】Redis全方位知识体系(附《Redis常用命令速查表(完整版)》)
java·数据库·redis·后端·python·spring·缓存
还是做不到嘛\.2 小时前
Dvwa靶场-SQL Injection
数据库·sql·web安全
楼田莉子2 小时前
MySQL数据库:MySQL的数据类型
数据库·学习·mysql
2401_879693872 小时前
数据分析与科学计算
jvm·数据库·python
LJianK13 小时前
java封装
java·前端·数据库
知识分享小能手4 小时前
MongoDB入门学习教程,从入门到精通,MongoDB查询(4)
数据库·学习·mongodb
LSL666_4 小时前
MybatisPlus条件构造器(上)
java·数据库·mysql·mybatisplus