问题描述:在MySQL中使用手动提交事务时,出现了Lock wait timeout exceeded; try restarting transaction 错误
解决方法:
LOCK WAIT timeout exceeded; try restarting TRANSACTION异常的错误提示是因为有数据行被锁住了。我们可以通过到information_schema
中来进行查找被锁的语句
解释:
information_schema
这张数据表保存了MySQL服务器所有数据库的信息。如数据库名,数据库的表,表栏的数据类型与访问权限等。再简单点,这台MySQL服务器上,到底有哪些数据库、各个数据库有哪些表,每张表的字段类型是什么,各个数据库要什么权限才能访问,等等信息都保存在information_schema表里面。
我们可以用下面三张表来查原因:
innodb_trx
当前运行的所有事务innodb_locks
当前出现的锁innodb_lock_waits
锁等待的对应关系
如果数据库中有锁的话,我们可以使用这条语句来查看:
select * from information_schema.innodb_trx;
执行上述命令,可以看到有线程ID为22327的线程正在运行中,如下图所示:
我们可以通过执行下述命令杀掉这个锁:
kill 线程ID号