首页 > 数据库技术 > 详细

mysql先删除后插入导致死锁

时间:2019-03-26 18:41:43      阅读:418      评论:0      收藏:0      [点我收藏+]

所报的错误为:pymysql.err.OperationalError: (1213, ‘Deadlock found when trying to get lock; try restarting transaction‘)

 

产生这个问题的原因:

  多个线程同时执行,且是先删除后插入,因为删除获取一种锁,插入获取一种锁,而这两种锁都没有解锁,就会冲突,导致报错,注意并不是所有的先删除后插入都会报错,具体参考:

  https://blog.csdn.net/weixin_34049948/article/details/87577738

产生错误的语句:

  goods_sn = ‘52142356‘

  delete from goods where goods_sn = goods_sn

  insert into goods values(goods_sn,1,0)

注意:上面删除语句的条件goods_sn和插入语句的goods_sn相同,或者相近,这和锁的区间有关系,具体参考:

  https://blog.csdn.net/hellozhxy/article/details/80455092

 

mysql先删除后插入导致死锁

原文:https://www.cnblogs.com/gunduzi/p/10601749.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!