问题:
修改数据库的时候,发现有两条数据一直无法修改(增删改都不可以),但是同库同表的其他数据都可以操作,数据库报错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
会显示有条数据状态为LOCK WAIT,使用以下语句终止这个进程就可以;
如果没有状态为LOCK WAIT的数据,可以重启下mysql 服务,再查询
kill 进程号