数据库并发控制-并发问题

作者:vkvi 来源:ITPOW(原创) 日期:2009-7-27

如果对数据库进行操作的事务是一个接一个地进行,不会带来什么问题,但这样效率很低,所以常常需要同时执行多个事务,如果没有什么控制的话,这种同时执行多个事务的情况就会带来许多问题。

丢失更新(记忆诀窍:读与写之间被插足了)

事务 T1 读取数据 A,然后对 A 进行运算修改,最后写回数据库。

如果在 T1 读取和写回数据库之间,有其他事务修改了 A 值,就造成了丢失更新,因为 T1 是在旧的数据上进行的运算。

脏读(记忆诀窍:读被晃点了)

事务 T1 修改了数据 A,然后事务 T2 读取了数据 A,然后事务 T1 回滚了事务。

由于事务 T1 回滚了事务,所以数据 A 其实最终并没有被事务 T1 修改,也就是说事务 T2 读取了被丢掉的数据。

不可重复读(记忆诀窍:读与读之间被插足了)

事务 T1 读取数据 A,然后做某些事,然后又读取数据 A。

如果在两次读取之间,有其他事务对数据 A 进行了修改,那么就造成了同一事务中,两次读取数据 A 的值不同。

相关阅读

相关文章