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 这类当前读的语句
相关推荐
CoderIsArt1 小时前
Redis的三种模式:主从模式,哨兵与集群模式
数据库·redis·缓存
师太,答应老衲吧3 小时前
SQL实战训练之,力扣:2020. 无流量的帐户数(递归)
数据库·sql·leetcode
Yaml44 小时前
Spring Boot 与 Vue 共筑二手书籍交易卓越平台
java·spring boot·后端·mysql·spring·vue·二手书籍
Channing Lewis4 小时前
salesforce case可以新建一个roll up 字段,统计出这个case下的email数量吗
数据库·salesforce
追风林4 小时前
mac 本地docker-mysql主从复制部署
mysql·macos·docker
毕业设计制作和分享5 小时前
ssm《数据库系统原理》课程平台的设计与实现+vue
前端·数据库·vue.js·oracle·mybatis
ketil275 小时前
Redis - String 字符串
数据库·redis·缓存
Hsu_kk6 小时前
MySQL 批量删除海量数据的几种方法
数据库·mysql
编程学无止境6 小时前
第02章 MySQL环境搭建
数据库·mysql
knight-n7 小时前
MYSQL库的操作
数据库·mysql