数据库-Lock wait timeout
一、问题抛出
前景:information_schema 数据库跟 performance_schema 一样,都是 MySQL 自带的信息数据库。其中 performance_schema 用于性能分析,而 information_schema 用于存储数据库元数据(关于数据的数据),例如数据库名、表名、列的数据类型、访问权限等。
information_schema 中的表实际上是视图,而不是基本表,因此,文件系统上没有与之相关的文件。
有时在做查询语句时,MySQL 抛出了这样的异常:
即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
三、三张表字段说明
innodb_trx
desc information_schema.innodb_trx;

innodb_locks
desc information_schema.innodb_locks;

innodb_lock_waits
desc information_schema.innodb_lock_waits


浙公网安备 33010602011771号