首页 > 代码库 > mysql 多版本并发控制
mysql 多版本并发控制
MVCC
通过给每张表多加两个隐藏列来实现,一个保存了行的创建时间,一个保存了行的过期时间(或删除时间),时间对应版本
创建一个新的事务,会创建一个新的版本号
前提条件
a. InnoDB只查找版本早于当前事务版本的数据行
b. 行的删除版本要么未定义,要么大于当前事务版本
处理机制
INSERT
InnoDB为新插入的每一行保存当前系统版本号作为行版本号
DELETE
InnoDB为删除的每一行保存当前系统版本好作为删除标识
UPDATE
InnoDB为插入一行新纪录,保存当前系统的版本号,同时将当前系统版本好保存到原来行的删除标识
以更新为例:
A,B 两个事务
A 事务
1. 创建A事务版本号为v1
2. 查询时 当前行的版本号为v1
3. 更新 先进行删除操作 版本号为v3 然后更新 行删除版本号为v3
B事务
1.创建B事务版本号为2
2. 查询时 当前行的版本号为2
3. 更新 先进行删除操作 版本号为v4 然后更新 行删除版本号为v4
两个事务同时更新会创建4条临时纪录
然后选择其中一条作为结果。
mysql 多版本并发控制
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。