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

 

相关文章:

  • 2021-12-24
  • 2021-04-07
  • 2021-06-05
  • 2021-10-20
  • 2021-05-05
  • 2021-04-10
  • 2022-12-23
猜你喜欢
  • 2022-12-23
  • 2022-12-23
  • 2021-07-24
  • 2020-07-07
  • 2021-11-11
  • 2018-10-19
  • 2022-12-23
相关资源
相似解决方案