2.事务与MVCC

1.ACID(通过银行转账进行说明)

注意:低级别隔离可以支持更高并发

 

2.隔离级别

  • 未提交读

2.事务与MVCC

  • 提交读
  • 可重复读

需要注意,可重复读保证同一事物多次读取同样记录的结果是一致的,但未解决幻读问题。幻读需要MVCC解决。

  • 串行化

 

3.MVCC

  • 概念

2.事务与MVCC

  • 实现方式

2.事务与MVCC

  • 应用示例

在REPEATABLE READ隔离级别下:

2.事务与MVCC

  • 需要注意:

2.事务与MVCC

  • 当前读

update数据时都是先读后写的,MVCC在此时读数据时,只能读当前的值,而不采用上述select的方式。称为“当前读”(也由此引发丢失更新问题)。

此外,select语句加显示锁,也是当前读。