mysql 版本链机制 & readView

2020-06-13  本文已影响0人  X1_blog

版本链机制 , readView

img

innodb表下存在两个隐藏列:

trx_id : 存放事务id

roll_pointer : 存放一个指向上一事务版本的指针

版本链的作用:

  1. 用一个单链表的结构存放每个事务版本对应的行的数据; 通过我当前的事务id可以获取对应的数据

  2. 配合readView的活跃事务数组可以判断当前应该读取哪个节点的数据, 如果我当前事务不在版本链上就向前读取节点直到读取的节点ID不在活跃事务数组中, 那么这个版本的数据就是最新的已提交数据

readView 结构:

m_ids: 一个列表, 存储当前系统活跃的事务id (重点)

min_trx_id: 存m_ids的最小值

max_trx_id: 系统分配给下一个事务的id

creator_trx_id: 生成readView事务的事务id

版本链,readView使用场景

https://www.bilibili.com/video/BV1ct411G7rB

上一篇下一篇

猜你喜欢

热点阅读