“简单讲讲你对 MVCC 的理解。”
“ MVCC 就是Mysql利用版本链机制实现了Mysql的隔离级别......”
很多老铁讲到MVCC只知道版本链,但是像ReadView、包括和UndoLog的关系就不太理解了,接下来就详细给大家讲讲 Mysql 跟 MVCC 的那些事。最近打算跳槽面试的请收藏好!
一、MVCC多版本并发控制机制
Mysql在可重复读隔离级别下如何保证事务较高的隔离性,我们上节课给大家演示过,同样的sql查询语句在一个事务里多次执行查询结果相同,就算其它事务对数据有修改也不会影响当前事务sql语句的查询结果。
这个隔离性就是靠MVCC(Multi-Version Concurrency Control)机制来保证的,对一行数据的读和写两个操作默认是不会通过加锁互斥来保证隔离性,避免了频繁加锁互斥,而在串行化隔离级别为了保证较高的隔离性是通过将所有操 作加锁互斥来实现的。
Mysql在读已提交和可重复读隔离级别下都实现了MVCC机制。
二、undo日志版本链与read view机制详解
undo日志版本链是指一行数据被多个事务依次修改过后,在每个事务修改完后,Mysql会保留修改前的数据undo回滚 日志,并且用两个隐藏字段trx_id和roll_pointer把这些undo日志串联起来形成一个历史记录版本链(见下图)
在可重复读隔离级别,当事务开启,执行任何查