MVCC究竟是什么?

1.MVCC概念

MVCC,全称多版本并发控制
MVCC究竟是什么?
通俗的来说MVCC就是为了在读取数据时不加锁来提高读取效率的一种办法,MVCC解决的是读写时线程安全问题,线程不用去抢占读写锁。MVCC中的读就是快照读,也就是普通的select语句。

2.MVCC原理

mvcc的具体实现通过数据库中的三个隐式字段、undolog、readview

其中三个隐式字段分别是:

  1. DB_TRX_ID:最近修改事务ID
  2. DB_ROLL_PTR:回滚指针,指向这条记录上一个版本,用于配合undolog,指向上一个版本
  3. DB_ROW_ID:隐藏主键,如果表结果没有指定主键,将会生成该隐藏字段

undolog(回滚日志):

在insert、update、delete的时候产生便于数据回滚的日志

readview(读视图):

是快照读SQL执行时MVCC提取数据的依据(通俗的来说就是select的时候我们需要知道可以读取哪个版本下的数据),记录并维护当前活跃的事务,read view中包含四个核心字段

  1. m_ids:当前活跃的事务ID集合
  2. min_trx_id:最小活跃事务ID
  3. max_trx_id:预分配事务ID,当前最大事务ID+1(因为事务ID是自增的)
  4. 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,所以每次读取的结果都一样

你可能感兴趣的:(数据库,oracle)