mysql先删除后插入导致死锁

所报的错误为: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

猜你喜欢

转载自www.cnblogs.com/gunduzi/p/10601749.html
今日推荐