Mysql 事务并发处理的三种异常

脏读(Dirty Read)【一个事务可能读取到另一个事务更新但未提交的数据,这个数据有可能是脏数据

 

不可重复读(Nnrepeatable Read)【事务不可重复读同一条记录,因为很可能读到的结果不一致

 

幻读(Phantom Read)【幻读就是没有读到的记录,以为不存在,但其实是可以更新成功的,并且,更新成功后,再次读取,就出现了。】

 

A1访问数据库,正在进行事务,往表B里加入一条记录,但是还未提交该事务,此时A2也去访问数据库了,这个时候,A2可以看到A1加入的数据,这种现象就是脏读。

A2访问数据库查看id=1的数据,这个时候A1访问数据库,开始了一个事务,更新了id=1的数据,且没有提交。然后A2又去访问数据库查看id=1的数据,看到的数据跟第一次看到的数据不一样,而是A1更新的数据,这种现象就是不可重复读。

A2访问数据库,查看B表里的全部数据。这个时候A1又往B表里加一条记录,开始了事务但是还未提交。这个时候A2又去查看了一下,就出现了A1加进去的但还未提交的数据,这种现象就是幻读。

posted @ 2021-04-29 17:23  lenlewan  阅读(306)  评论(0)    收藏  举报