Waiting for table metadata lock mysql出现此错误解决办法

出现这种情况的说明,我是需要去修改表的结构,但是一修改,就直接卡死,然后就会报 Waiting for table metadata lock 这个错. 实际上,这个错不止是修改表结构会出现,你对这张表的任务锁表操作,都将不能实现.

解决方法

一 : 首先排除所有的长事物,慢查询等阻塞ddl,这类操作,会阻塞后续的操作

使用 show processlist 可以看到 一个列表 ,在这个列表里面有个字段info 就是当前阻塞的长事物的sql语句, 如果发现有这样的语音,kill掉 id即可
在这里插入图片描述

如图,为了演示,我使用了 一句sql (select sleep(30) ) 来模拟阻塞…

假设是这条sql是 造成阻塞的元凶,那么执行
kill 47660 ;
即可释放

二: 再排除 未提交的事物 ,这类也会阻塞ddl ,阻塞后续操作
刚才通过 show processlist 命令没有任务正在阻塞的操作,但是,实际上有 未提交的事物存在.这就需要去information_schema.innodb_trx 的这个表中去查看了.
使用 这个sql 命令 进行查看, 需要root用户或者足够的权限才能查看.

SELECT * FROM information_schema.innodb_trx

如果这个sql能查询出结果,如图 :
在这里插入图片描述

则是有阻塞了…
执行kill 命令即可强制释放掉对应的线程
如: kill 47660

根据官方的解释这个操作是
官方手册上对此的说明如下:

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值