0

MySQL的脏读、幻读、不可重复读是什么

 4 weeks ago
source link: https://www.51cto.com/article/786569.html
Go to the source link to view the article. You can view the picture content, updated content and better typesetting reading experience. If the link is broken, please click the button below to view the snapshot at that time.

MySQL的脏读、幻读、不可重复读是什么

作者:派大星 2024-04-19 08:18:47
脏读、不可重复读和幻读这三种异常现象是在SQL-92标准中定义的,同时,SQL-92标准还确定了4种隔离级别来处理这些异常情况,按照严格程度从高到低排列分别为:顺序执行(Serializable)、可重复读(Repeatable reads)、提交读(Read committed)、未提交读(Read uncommitted)。

脏读:指读取了其他事务尚未提交的数据,可能导致不一致性。

不可重复读:在对数据进行读取的过程中,有其他事务对数据进行了修改(UPDATE、DELETE),导致第二次读取的结果与第一次不一致。

幻读:指一个事务在进行范围查询时,另一个事务在该范围内进行新增操作(INSERT),导致范围查询的结果数目不一致。

什么是脏读

脏读又称为无效数据读取,指在数据库访问中,事务T1修改了某个数值,随后事务T2读取了该数值,而后因某种原因,T1撤销了对该数值的修改,导致T2读取到的数据变为无效。

具体而言,脏读是指一个事务正在访问数据并对其进行修改,但这些修改尚未提交到数据库中。此时,另一个事务也访问该数据,并使用了它。由于这些数据尚未提交,另一个事务所读取的数据就会成为脏数据,基于这些脏数据所做的操作可能会产生不正确的结果。

什么是幻读

幻读是指在事务非独立执行时出现的现象,举例来说,第一个事务对表中的数据进行了修改,涉及到表中的“全部数据行”。与此同时,第二个事务也修改了该表的数据,插入了“一行新数据”。随后,操作第一个事务的用户发现表中仍然存在未修改的数据行,就好像出现了幻觉一般。

一般解决幻读的方法是通过增加范围锁(RangeS),将检测锁的范围限定为只读,这样便可以避免幻读的发生。

值得注意的是,幻读是不可重复读的一种特殊情况:在事务没有获取范围锁的情况下执行SELECT … WHERE操作时可能会导致幻读现象的发生。

什么是不可重复读

不可重复读是指在数据库访问中,一个事务内进行两次相同的查询却返回了不同的数据。这种现象是由于系统中其他事务的提交修改所引起的。例如,事务T1读取某一数据,事务T2读取并修改了该数据,随后T1为了检验读取值再次读取该数据,结果获取到不同的数值。

更通俗易懂的说法是:在一个事务中多次读取同一数据,在该事务未结束之前,另一个事务也访问同一数据。在第一个事务两次读取数据之间,由于第二个事务的修改,导致第一个事务读取到的数据可能不同,这就导致了在同一个事务内两次读取数据的结果不一致,因此称为不可重复读,即原始读取结果不可重复。

扩展知识之事务隔离级别

脏读、不可重复读和幻读这三种异常现象是在SQL-92标准中定义的,同时,SQL-92标准还确定了4种隔离级别来处理这些异常情况,按照严格程度从高到低排列分别为:顺序执行(Serializable)、可重复读(Repeatable reads)、提交读(Read committed)、未提交读(Read uncommitted)。

责任编辑:武晓燕 来源: 码上遇见你

About Joyk


Aggregate valuable and interesting links.
Joyk means Joy of geeK