java sqlserver 死锁_sql-server – SQLServer死锁

我有一个

java应用程序,它在数据库上执行多个并发CRUD操作.我正在添加对SQLServer的支持,但在并发删除期间遇到死锁问题.经过一些调查后,似乎问题可能是由于特定桌子上的锁升级造成的.

为了解决这个问题,我决定使用UPDLOCK提示对所讨论的表进行所有读取“for update”,以便可以避免死锁.但是,我仍然看到了这个问题.我在SQLServer中启用了跟踪,并在SQLServer日志中找到了以下死锁跟踪:

遇到死锁….打印死锁信息

等待图表

节点:1

KEY:5:72057594042384384(54048e7b3828)CleanCnt:3模式:X标志:0x0

拨款清单1:

所有者:0x03D08C40模式:X Flg:0x0参考:0寿命:02000000 SPID:62 ECID:0 XactLockInfo:0x04834274

SPID:62 ECID:0语句类型:DELETE行#:1

输入Buf:语言事件:(@ P0 nvarchar(4000))从part_data中删除part_id = @ P0

被要求:

ResType:LockOwner Stype:’OR’Xdes:0x04B511C8模式:U SPID:60 BatchID:0 ECID:0 TaskProxy:(0x058BE378)值:0x3d08500成本:(0/1296)

节点:2

KEY:5:72057594042384384(f903d6d6e0ac)CleanCnt:2模式:X标志:0x0

拨款清单0:

所有者:0x03D088A0模式:X Flg:0x0参考:0寿命:02000000 SPID:60 ECID:0 XactLockInfo:0x04B511EC

SPID:60 ECID:0语句类型:DELETE行#:1

输入Buf:语言事件:(@ P0 nvarchar(4000))从part_data中删除part_id = @ P0

被要求:

ResType:LockOwner Stype:’OR’Xdes:0x04834250 Mode:U SPID:62 BatchID:0 ECID:0 TaskProxy:(0x047BA378)Value:0x3d089e0 Cost:(0/4588)

受害者资源所有者:

ResType:LockOwner Stype:’OR’Xdes:0x04B511C8模式:U SPID:60 BatchID:0 ECID:0 TaskProxy:(0x058BE378)值:0x3d08500成本:(0/1296)

SQLServer探查器将此显示为两个持有更新(U)锁并尝试升级到独占(X)锁的客户端.我读过的SQLServer文档说在给定时间只有一个客户端可以在表上有一个(U)锁,所以我想知道为什么我看到跟踪中显示的情况.

该跟踪中引用的数据库对象是外键的索引.如果有经验解决这类问题的人可以提供建议,那将是一个很大的帮助.

谢谢,

布拉德.

编辑按要求添加了死锁图xml:

delete from part_data where part_id = @P0

(@P0 nvarchar(4000))delete from part_data where part_id = @P0

delete from part_data where part_id = @P0

(@P0 nvarchar(4000))delete from part_data where part_id = @P0

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值