其他分享
首页 > 其他分享> > Lock wait timeout exceeded; try restarting transaction

Lock wait timeout exceeded; try restarting transaction

作者:互联网

一.问题描述

在做查询语句时,MySQL 抛出了这样的异常:锁等待超时 Lock wait timeout exceeded; try restarting transaction,是当前事务在等待其它事务释放锁资源造成的!

二.解决方案

1、数据库中执行如下sql,查看当前数据库的线程情况:
     show full PROCESSLIST
2、INNODB_TRX 表的 trx_mysql_thread_id  字段对应 show full processlist 中的Id);如果在,就说明这个 sleep 的线程事务一直没有 commit 或者 rollback,而是卡住了,需要我们手动删除。
      select * from information_schema.innodb_trx
3、将找到的 trx_mysql_thread_id 手动删除:
    若 trx_mysql_thread_id 为 1816 即 kill 1816 即可

标签:transaction,thread,show,Lock,exceeded,try,trx,mysql,id
来源: https://www.cnblogs.com/songwp/p/16223481.html