MySQL之多版本并发控制MVCC

MVCC是一种用于实现数据库读提交和可重复读隔离级别的并发控制技术。它通过创建一致性视图确保事务间修改互不影响。快照读在事务开始时建立一致性视图,保证可重复读;而当前读则总是获取最新数据。MVCC通过undo日志记录数据的不同版本,使事务能够读取到符合条件的历史版本,从而避免锁竞争,提高并发性能。
摘要由CSDN通过智能技术生成

MVCC

mvcc中文名称为多版本并发控制,用于实现读提交和可重复读隔离级别。多版本是指在对数据进行修改时,会通过undo日志记录数据行的多个版本。

一致性视图

通过建立一致性视图,实现事务间的修改不相互影响。一致性视图,记录了当前正在执行的所有事务id。

对于可重复读隔离级别,在事务执行过程中读取到的数据是一致的。读取一行数据时,实际会去判断当前数据的事务编号。如果事务id大于当前视图的高水位,说明这是一个未来的事务修改的数据,不能读取。这时就会往前追溯,找到一个undo日志版本号小于当前视图的低水位,或则位于高低水位之间但不在视图开始时记录的正在执行的事务id集合中,就是当前事务可见的数据。

快照读和当前读

以上这种读取数据的方式叫做快照读。对于读提交,在每次select语句前建立一致性视图。而对于可重复读,在事务开始时建立一致性视图。

和快照读相对的是当前读,当前读总数读取最新的数据。在读未提交隔离级别下总是采用当前读。在读已提交和可重复读级别下,当在update、select for update 、select in share mode等请况下也是当前读。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值