您好,欢迎访问一九零五行业门户网

MySQL多版本并发控制分析

今天我用mysql验证这个问题的仔细研究了一下mysql的后台实现,后来再网上发现了下面这篇文章非常就转过来,不过文中有些地方逻辑
背景:
之前面试被问到这么一个问题,数据库两个transaction,当transaction1在update某一行的时候,transaction2在select的时候会不会block。我以前用mysql做过测试,印象是可以,但是面试官提出质疑,今天我用mysql验证这个问题的仔细研究了一下mysql的后台实现,后来再网上发现了下面这篇文章非常就转过来,不过文中有些地方逻辑上好像不太对,我没有时间去读mysql源代码,就根据实际结果给出自己的推测,如果大家有明确答案请共享之。 
我先把文中感觉不对的地方我自己总结的放出来(标红的为我的猜测),大家可以先看正文,然后再回头看我的总结: 
正文链接如下:  
mysql到底是怎么实现mvcc的?这个问题无数人都在问,,但google中并无答案,本文尝试从mysql源码中寻找答案。
在mysql中mvcc是在innodb存储引擎中得到支持的,innodb为每行记录都实现了三个隐藏字段:
6字节的事物id用来标识该行所述的事务,7字节的回滚指针需要了解下innodb的事务模型。
1. innodb的事务相关概念为了支持事务,innbodb引入了下面几个概念:
接下来请看第2页精彩内容:
其它类似信息

推荐信息