Mysql gap lock引起的一个问题

有时候,我们的后天日志会出现mysql的一些异常,异常信息大概是:Lock wait timeout exceeded try restarting transaction,或者还有...gap...灯字样。

这个原因,一般都是一个线程中的业务逻辑需要先delete,再insert;或者是两个线程,一个线程在delete,一个线程在insert。

关键就在这个delete的where条件上,如果where条件是主键,不会有上面这个问题出现。
如果是普通索引,就会有这个问题出现的可能,这个涉及到的是gap lock问题,当delete where这个语句没有满足条件的记录时,mysql会尝试锁住索引中,where条件的上下位置的其他记录。如果此时要insert记录到其他位置,就会出现这个错误。

举例:
t1中,有数据
1,2,3,7,8,
现在业务方法的逻辑是:
delete from t1 where a=4;
insert t1 (a) values(5);
这时就有异常抛出了。

因为delete where a=4时,表中没有满足条件的记录,mysql会锁住3,7这个区间的索引,此时又要insert 5,这个5 刚好落在3,7这个区间内,也要获得区间3,7的锁才行,这样就造成死锁了。

因此,在需要先delete再insert的业务方法中,在delete前先用相同条件selete一下,有数据则再delete,否则直接insert即可。
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值