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

简介:
在数据库中经常会遇到这样的情况:一个主表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进行操作。因为删除规则设置为层叠以后,删除主表中的数据,子表中所有外键关联的数据也同时删除了。

以上三个解决办法都是同事给出的建议,我也不知道到底该使用什么办法才好。
不知道对于这种情况要防止死锁大家还有没有什么其他好办法?
目录
相关文章
|
5月前
|
SQL 存储 Oracle
数据库系列课程(20)-数据库死锁的原因及解决方案
数据库系列课程(20)-数据库死锁的原因及解决方案
57 0
|
6月前
|
SQL Oracle 关系型数据库
关于 SAP HANA 数据库的死锁问题(deadlock)
关于 SAP HANA 数据库的死锁问题(deadlock)
97 0
|
9月前
|
安全 数据库
数据库死锁讲解
数据库死锁讲解
81 0
|
11月前
|
SQL 算法 前端开发
开源分布式数据库PolarDB-X源码解读——PolarDB-X源码解读(六):分布式死锁检测
开源分布式数据库PolarDB-X源码解读——PolarDB-X源码解读(六):分布式死锁检测
329 0
|
监控 关系型数据库 MySQL
MySQL性能优化-数据库死锁监控
MySQL性能优化-数据库死锁监控
246 0
|
SQL 关系型数据库 MySQL
数据库的死锁原因及优化方案
数据库的死锁原因及优化方案
2731 16
数据库的死锁原因及优化方案
|
SQL 监控 Oracle
oracle 数据库中的行锁和死锁
Oracle数据库中发生行锁和死锁时的分析思路、工具和解决办法
1349 0
数据库——删除表中的级联的含义
通过以下这个例子来说明我对数据库当中删除表的级联的含义的理解。 现在有一张表,名字叫PTYPES
数据库——删除表中的级联的含义
|
数据库 索引 关系型数据库
一次诡异的数据库“死锁”,问题究竟在哪里?
程序死锁的问题,很难调试,看进程堆栈,看各个线程与锁的情况,对照代码进行排查。数据库死锁的问题,更难,看不了数据库堆栈,也看不了数据库线程与锁,更难以对照代码排查。
551 0

热门文章

最新文章