二十六、事务的隔离级别

tech2022-09-05  121

事务的隔离级别

隔离级别

事务的隔离级别决定了事务之间可见的级别。

当多个客户端并发地访问同一个表时,可能出现下面的一致性问题:

(1)脏读取(Dirty Read) 

一个事务开始读取了某行数据,但是另外一个事务已经更新了此数据但没有能够及时提交,这就出现了脏读取。

(2)不可重复读(Non-repeatable Read) 

在同一个事务中,同一个读操作对同一个数据的前后两次读取产生了不同的结果,这就是不可重复读。

 

(3)幻像读(Phantom Read) 

幻像读是指在同一个事务中以前没有的行,由于其他事务的提交而出现的新行。

四个隔离级别

InnoDB 实现了四个隔离级别,用以控制事务所做的修改,并将修改通告至其它并发的事务:

(1)读未提交(READ UMCOMMITTED) 

允许一个事务可以看到其他事务未提交的修改。

(2)读已提交(READ COMMITTED) 

允许一个事务只能看到其他事务已经提交的修改,未提交的修改是不可见的。

 

(3)可重复读(REPEATABLE READ) 

确保如果在一个事务中执行两次相同的SELECT语句,都能得到相同的结果,不管其他事务是否提交这些修改。 

该隔离级别为InnoDB的缺省设置。

 

(4)串行化(SERIALIZABLE) 【序列化】

将一个事务与其他事务完全地隔离。 

例:A可以开启事物,B也可以开启事物

A在事物中执行DML语句时,未提交

B不以执行DML,DQL语句

 

隔离级别与一致性问题的关系

 

 

最新回复(0)