Rumah  >  Artikel  >  pangkalan data  >  MySQL多版本并发控制分析

MySQL多版本并发控制分析

WBOY
WBOYasal
2016-06-07 17:32:351036semak imbas

今天我用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页精彩内容

linux

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn