Rumah  >  Artikel  >  幻读是什么?

幻读是什么?

Guanhui
Guanhuiasal
2020-06-11 11:35:509105semak imbas

幻读是什么?

幻读是什么?

幻读就是事务A首先根据条件索引得到N条数据,然后事务B改变了这N条数据之外的M条或者增添了M条符合事务A搜索条件的数据,导致事务A再次搜索发现有N+M条数据了,这就会产生幻读。

如何解决幻读?

  • 通过 next-key lock解决。

  • 产生幻读的原因是,行锁只能锁住行,但是新插入记录这个动作,要更新的是记录之间的“间隙”。因此,为了解决幻读,InnoDB引入间隙锁。

  • Gap lock间隙锁在可重复读级别下才有效

  • 间隙锁和行锁合称 next-key lock,每个 next-key lock 是前开后闭区间。

在数据库定义的四种隔离级别中

最高隔离级别SERIALIZABLE_READ可以保证不出现幻读的问题。

Repeatable Read (RR)

针对当前读,RR隔离级别保证对读取到的记录加锁 (记录锁),同时保证对读取的范围加锁,新的满足查询条件的记录不能够插入 (间隙锁),不存在幻读现象。


推荐教程:《MySQL教程

Atas ialah kandungan terperinci 幻读是什么?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Artikel sebelumnya:RN 程序员是什么?Artikel seterusnya:数据的三大来源是什么?