数据库面经 MVCC机制

MVCC(Multi-Version Concurrency Control)多版本并发控制,用于管理多个事务同时访问和修改数据库的数据,而不会导致数据不一致和冲突。MVCC的核心思想是每个事务在数据库中看到的数据版本是事务开始时的一个快照,而不是实际的最新版本。这使得多个事务可以并发执行,而不会相互干扰。

Mysql的事务有ACID四大特性,其中的隔离性可以通过锁和MVCC来实现,MVCC适合在一些锁性能较差的情况下使用,提高效率。

下述如何实现:

每一个UndoLog日志都有一个 roll_pointer(回滚指针)用于指向上一个版本的Undo Log。这样对于每一个记录就会构成一个版本链,用于记录所有修改,每一次进行新的修改后,新的Undo Log会放在版本链的头部。

那么对于查询时应该查询哪个版本呢,这时就需要用Readview实现。

在事务select查询数据时,就会构造一个readview,它包含了版本链的统计信息

m_ids 当前活跃的所有事务id(所有未提交的事务)

min_trx_id 版本链尾的id

max_trx_id 下一个将要分配的事务id(版本链头事务id+1)

creator_trx_id 创建这个Readview事务id的查询规则:

该版本是否为当前事务创建(读取自己修改的数据),如果是就返回,否则进入下一个判断。

该版本的事务id是否小于min_trx_id(在Readview创建之前,数据已经提交),可以直接访问。

........................是否大于max_trx_id(在ReadView创建后,该版本才开启),不能被访问。

若在他们俩之间,则判断该版本事务id是否在m_ids中,如果不在说明事务可以提交访问,否则不能访问。

  • 9
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值