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 这类当前读的语句
相关推荐
柊二三2 小时前
XML的简略知识点
xml·数据库·oracle
每天敲200行代码4 小时前
MySQL 事务管理
数据库·mysql·事务
巴里巴气5 小时前
MongoDB索引及其原理
数据库·mongodb
程序员勋勋15 小时前
Redis的String数据类型底层实现
数据库·redis·缓存
不修×蝙蝠5 小时前
MySQL 全详解:从入门到精通的实战指南
数据库·mysql·索引·最左前缀
我的ID配享太庙呀7 小时前
Django 科普介绍:从入门到了解其核心魅力
数据库·后端·python·mysql·django·sqlite
不辉放弃8 小时前
kafka的消费者负载均衡机制
数据库·分布式·kafka·负载均衡
拉姆哥的小屋8 小时前
用 Flask 打造宠物店线上平台:从 0 到 1 的全栈开发实践
数据库·oracle·flask
liliangcsdn8 小时前
mac neo4j install & verifcation
数据库·neo4j
Cyanto9 小时前
MyBatis-Plus高效开发实战
java·开发语言·数据库