MVCC,全称多版本并发控制
MVCC究竟是什么?
通俗的来说MVCC就是为了在读取数据时不加锁来提高读取效率的一种办法,MVCC解决的是读写时线程安全问题,线程不用去抢占读写锁。MVCC中的读就是快照读,也就是普通的select语句。
mvcc的具体实现通过数据库中的三个隐式字段、undolog、readview
- DB_TRX_ID:最近修改事务ID
- DB_ROLL_PTR:回滚指针,指向这条记录上一个版本,用于配合undolog,指向上一个版本
- DB_ROW_ID:隐藏主键,如果表结果没有指定主键,将会生成该隐藏字段
在insert、update、delete的时候产生便于数据回滚的日志
是快照读SQL执行时MVCC提取数据的依据(通俗的来说就是select的时候我们需要知道可以读取哪个版本下的数据),记录并维护当前活跃的事务,read view中包含四个核心字段:
- m_ids:当前活跃的事务ID集合
- min_trx_id:最小活跃事务ID
- max_trx_id:预分配事务ID,当前最大事务ID+1(因为事务ID是自增的)
- creator_trx_id:readview创建者的事务ID
readview中规定了版本链的访问规则,trx_id表示当前事务id:
- 1.trx_id==creator_trx_id:可以访问该版本,说明数据是当前这个事务更改的
- 2.trx_id
可以访问,说明数据已经提交了 - 3.trx_id>max_trx_id:不可以访问,说明事务时在readview生成之后才开启的
- 4.min_trx_id<=trx_id<=max_trx_id:如果trx_id不在m_idx中,是可以访问该版本的,说明数据已经提交
不同的隔离级别生成readview的时机不同:
- read committed:在事务每执行一次快照时生成readview
- repeatable read:仅在同一事务第一次快照读时生成readview,后续复用该readview,所以每次读取的结果都一样