MySQL事务 - ReadView

1、概念理解

隔离级别中提到:

  • 对于使用READ UNCOMMITTED隔离级别的事务来说,直接读取记录的最新版本就好了。
  • 对于使用SERIALIZABLE隔离级别的事务来说,使用加锁的方式来访问记录。
  • 对于使用READ COMMITTEDREPEATABLE READ隔离级别的事务来说,就需要通过ReadView追溯版本链

核心问题就是:需要判断一下版本链中的哪个版本是当前事务可见的。所以设计InnoDB的设计者提出了一个ReadView的概念,这个ReadView中主要包含当前系统中还有哪些活跃的读写事务,把它们的事务id放到一个列表中,我们把这个列表命名为为m_ids

这样在访问某条记录时,只需要按照下边的步骤判断该记录在版本链中的某个版本(trx_id)是否可见:

  • trx_id < m_ids列表中最小的事务id
    表明生成该版本的事务在生成ReadView前已经提交,所以该版本可以被当前事务访问。
  • trx_id > m_ids列表中最大的事务id
    表明生成该版本的事务在生成ReadView 后才生成,所以该版本不可以被当前事务访问。
  • m_ids列表中最小的事务id < trx_id < m_ids列表中最大的事务id
    (1)trx_id在m_ids中:说明创建 ReadView 时生成该版本的事务还是活跃的,该版本不可以被访问。
    (2)trx_id不在m_ids中:说明创建 ReadView 时生成该版本的事务已
  • 7
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值