码迷,mamicode.com
首页 > 数据库 > 详细

mysql 多版本并发控制

时间:2016-12-30 20:43:21      阅读:265      评论:0      收藏:0      [点我收藏+]

标签:技术   技术分享   src   数据   upd   insert   ges   定义   版本号   

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 多版本并发控制

标签:技术   技术分享   src   数据   upd   insert   ges   定义   版本号   

原文地址:http://www.cnblogs.com/mengjianzhou/p/6237881.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!