如何防止插入删除表造成的数据库死锁

2008-02-23 07:39:40来源:互联网 阅读 ()

新老客户大回馈,云服务器低至5折

在数据库中经常会碰到这样的情况:一个主表A,一个子表B,B表中包含有A表的主键作为外键。当要插入数据的时候,我们会先插入A表,然后获得A表的Identity,再插入B表。假如要进行删除操作,那么就先删除子表B,然后再删除主表A。在程式设计中,对两个表的操作是在一个事务之中完成的。

当系统使用频繁就会出现插入操作和删除操作同时进行的情况。这个时候插入事务会先将主表A放置独占锁,然后去访问子表B,而同时删除事务会对子表B放置独占锁,然后去访问主表A。插入事务会一直独占着A表,等待访问B表,删除事务也一直独占着B表等待访问A表,于是两个事务相互独占一个表,等待对方释放资源,这样就造成了死锁。

碰到这种情况我听说了三种做法:

1 取消AB两个表之间的外键关系,这样就能够在删除数据的时候就能够先删除主表A,然后删除子表B,让对这两个表操作的事务访问顺序一致。

2 删除A表数据之前,先使用一个事务将B表中相关外键指向另外A表中的另外一个数据(比如在A表中专门建一行数据,主键配置为0,永远不会对这行数据执行删除操作),这样就消除了要被删除的数据在AB两个表中的关系。然后就能够使用删除事务,先删除A表中的数据,再删除B表中的数据,以达到和插入事务表访问一致,避免死锁。

3 在外键关系中,将“删除规则”配置为“层叠”,这样删除事务只需要直接去删除主表A,而无需对子表B进行操作。因为删除规则配置为层叠以后,删除主表中的数据,子表中任何外键关联的数据也同时删除了。

以上三个解决办法都是同事给出的建议,我也不知道到底该使用什么办法才好。

不知道对于这种情况要防止死锁大家更有没有什么其他好办法?


标签:

版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有

上一篇: MySQL密码忘记了,别害怕

下一篇: MySQL是否值得我们选择的正反五个理由