码迷,mamicode.com
首页 > Web开发 > 详细

MVCC

时间:2017-04-21 23:43:59      阅读:207      评论:0      收藏:0      [点我收藏+]

标签:read   保存数据   修改   数据   commit   table   记录   级别   提升   

Mysql的大多数事务型存储引擎实现的都不是简单的行级锁。基于提升并发性能的考虑,他们一般都同时实现了MVCC.实现了非阻塞的读操作,写操作也只锁定必要的行。

MVCC的实现,是通过保存数据在某个时间点的快照来实现的。即为:不管需要执行多长时间,每个事务看到的数据都是一致的。

不同的存储引擎的MVCC实现不同,典型的有乐观并发控制和悲观并发控制。

innodb的MVCC,是通过在每行记录后面保存两个隐藏的列来实现的。这两个列,一个是行的创建时间,一个保存行的过期时间。存储的是系统版本号,不是真实的时间。每开始一个新的事务,系统版本号都会自动递增。事务开始时刻的系统版本号会作为事务的版本号,用来和查询到的每行记录的版本号进行比较。

在REPEATABLE READ隔离级别下,MVCC具体操作:

SELECT

  innodb会根据以下两个条件检查每行记录:

    a.innodb只查找版本号早于当前事务版本的数据行,<=当前事务版本号,这样可以确保事务读取的行,要么是在事务开始前已经存在的,要么是事务自身插入或者修改过的

    b.行的删除版本要么未定义,要么大于当前的事务版本号。这可以确保事务读取到的行,在事务开始之前未被删除。

INSERT

  INNODB为新插入的每一行保存当前系统版本号作为行版本号

DELETE

  innodb为删除的每一行保存当前系统版本号作为行删除标识

UPDATE

  innodb为插入一行新纪录,保存当前系统版本号为行版本号,同时保存当前系统版本号到原来的行作为行删除标识

MVCC只在repeatable read和read committed两个隔离级别下工作。其他两个隔离级别和MVCC不兼容。因为READ UNCOMMITTED 总是读取最新的数据行,而不是符合当前事务版本的数据行。而SERIALIZABLE 则会对所有读取的行都加锁。

 

MVCC

标签:read   保存数据   修改   数据   commit   table   记录   级别   提升   

原文地址:http://www.cnblogs.com/maggie94/p/6746549.html

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