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