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

作者:vkvi 来源:千一网络(原创) 日期:2009-7-27

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

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

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

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

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

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

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

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

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

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

相关阅读

你前面那位网友看了:PHP 的 isset、unset 是什么意思?

▲▲▲嘿,欢迎转载传播本站原创文章,尽量保留来源噢。▲▲▲

文章评论
标题:必填
内容:
本站永远终止与捏造“罪名”不支付广告费的某度联盟合作。
vkvi
vkvi

作者简介: vkvi,致力于 .NET Web 开发、移动开发的技术推广,在 .NET、SQL Server、Windows Server 等方面有深入研究和丰富经验,10 年间共计撰写文章 4000 余篇。 主持金融、国土、农业、电商等多个行业项目执行, 推行“技术提升生产力、人心决定成功率”的管理理论。 联系他