mysql deadlock found when trying to get lock暴力解决

如若你在运行代码时出现此问题,那么此博客可以略过了。

如若你也不知道怎么操作后,突然对表进行增删查改的操作后,出现此问题,那么采用暴力解决法

方案一:

1、查询是否锁表

show OPEN TABLES where In_use >0;

2、在mysql黑框中或者navicat查询界面中输入:

show processlist;

查看mysql当前的全部线程。(只能查看这个账户下操作的线程)

2、利用kill id(上面命令的id列) ,杀死Command为Query的进程即可

方案2:

1、查看在锁的事务

select * from information_schema.innodb_trx; 查看下在锁的事务

2、杀死进程id(上面命令汇总的trx_mysql_thread_id列)

kill 线程ID

附:其他查看死锁的命令:

1:查看当前的事务
SELECT * FROM INFORMATION_SCHEMA.INNODB_TRX;

2:查看当前锁定的事务

SELECT * FROM INFORMATION_SCHEMA.INNODB_LOCKS;

3:查看当前等锁的事务
SELECT * FROM INFORMATION_SCHEMA.INNODB_LOCK_WAITS; 

参考自:https://blog.csdn.net/ejinxian/article/details/79212329

 

当尝试获取锁时发现死锁。这个问题可能是由于并发事务之间的争用锁资源引起的。为了解决这个问题,可以尝试以下几种方法: 1. 序列化事务方法:创建一个仅包含一行的辅助“信号量”表,并让每个事务在访问其他表之前更新该行。这样可以确保所有事务以串行方式发生,避免了死锁的发生。请注意,这种方法适用于InnoDB引擎的行级锁,对于MySQL表级锁,则需要使用超时方法来解决死锁。 [1] 2. 降低隔离级别:如果您使用锁定读取(SELECT ... FOR UPDATE或SELECT ... LOCK IN SHARE MODE),可以尝试使用较低的隔离级别,例如READ COMMITTED。这样可以减少锁的数量,降低死锁的概率。 [2] 3. 减少锁的使用:如果您可以承受读取旧快照的数据,可以避免使用FOR UPDATE或LOCK IN SHARE MODE来允许SELECT语句返回旧快照的数据。在READ COMMITTED隔离级别下,每个一致性读取都会从自己的新快照中读取,这样可以减少锁的使用。 [3] 以上是解决"Deadlock found when trying to get lock"问题的几种方法。根据具体情况,您可以选择适合您应用程序的方法来避免死锁的发生。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [难得一见的数据库事务异常 Deadlock found when trying to get lock解决办法dao....](https://blog.csdn.net/u011488009/article/details/111173576)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

chde2Wang

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值