MySQL的MVCC和幻读解决策略

MVCC

InnoDB的MVCC,是通过在每行记录后面保存两个隐藏的列来实现。这两个列,一个保存了行的创建时间,一个保存行的删除时间,并不是实际的时间,而是系统版本号。每开始一个新的事务,系统版本号都会自动递增。事务开始时刻的系统版本号会作为事务的版本号,用来和查询到的每行记录的版本号作比较,MVCC只在可重读读和提交读两种隔离级别下工作。

可重复读下的MVCC的操作方法

  • SELECT
    InnoDB会根据以下两个条件检查每行记录:
    1.InnoDB只查询版本早于当前事务版本的数据行(也就是,行的系统版本号小于或等于事务的系统版本号),这样可以确保事务读取的行,要么是在事务开始前已经存在的,要么是事务自身插入或者修改过的);
    2.行的删除版本要么未定义,要么大于当前事务版本号。这可以确保事务读取到的行,在事务之前未被删除。
    只有符合上述两个条件的记录,才能返回作为查询结果。

  • INSERT
    InnoDB为新插入的每一行保存当前系统版本号作为行版本号。

  • DELETE
    InnoDB为删除的每一行保存当前系统版本号作为行删除标识。

  • UPDATE
    InnoDB为插入一行新记录,保存当前系统版本号作为行版本号,同时保存当前系统版本号到原来的行作为行删除标识。

幻读解决

  • 通过设置事务隔离级别为可串行化
  • next-key locking策略
    间隙锁,他就是给所有符合筛选范围的包括不存在的记录加锁,这不存在的记录就是所谓的间隙,这样的话再对这个范围内进行插入记录就不行了,就防止了再次以相同筛选条件查询时会返回不存在记录的问题了。

猜你喜欢

转载自blog.csdn.net/AIJXB/article/details/115236813