解决mysql插入数据锁等待超时报错:Lock wait timeout exceeded;try restarting transaction
报错信息

Lock wait timeout exceeded; try restarting transaction
锁等待超时 Lock wait timeout exceeded; try restarting transaction,是当前事务在等待其它事务释放锁资源造成的
解决办法
1、数据库中执行如下sql
查看当前数据库的线程情况:
show full PROCESSLIST

2、再到 INNODB_TRX 事务表中查看
看 trx_mysql_thread_id 是否在 show full processlist 里面的 sleep 线程中(INNODB_TRX 表的 trx_mysql_thread_id 字段对应 show full processlist 中的Id);
如果在,就说明这个 sleep 的线程事务一直没有 commit 或者 rollback,而是卡住了,需要我们手动删除。
select * from information_schema.innodb_trx


如上图,trx_mysql_thread_id 为 10557347
kill 10557347
总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
相关文章
MySQL错误1449: The user specified as
在使用MySQL数据库时,有时会遇到错误1449: The user specified as a definer ('root'@'%') does not exist,本文将详细介绍这个错误的原因以及如何解决它,需要的朋友可以参考下2025-05-05


最新评论