MySQL出现Waiting for table metadata lock的原因以及解决方法(已亲测)

参考:MySQL出现Waiting for table metadata lock的原因以及解决方法 - digdeep - 博客园

当对表执行truncatedrop 操作时,会出现一直处于等待的状态,通过show processlist可以看到TableA停滞在Waiting for table metadata lock的状态。kill 进程号之后,重新进行truncate还是出现等待状态,通过 select * frominformation_schema.innodb_trx找到未提交事物的sid, 然后 kill 掉,让其回滚。

产生Waiting for table metadata lock的原因其实很简单,一般是以下几个简单的场景:

场景一:长事物运行,阻塞DDL,继而阻塞所有同表的后续操作

场景二:未提交事物,阻塞DDL,继而阻塞所有同表的后续操作

场景三:

通过show processlist看不到TableA上有任何操作,在information_schema.innodb_trx中也没有任何进行中的事务。这很可能是因为在一个显式的事务中,对TableA进行了一个失败的操作(比如查询了一个不存在的字段),这时事务没有开始,但是失败语句获取到的锁依然有效,没有释放。从performance_schema.events_statements_current表中可以查到失败的语句。

相关推荐
小跌—2 小时前
Redis的string数据类型
数据库·redis·缓存
清水白石0082 小时前
函数签名内省实战:打造通用参数验证装饰器的完整指南
java·linux·数据库
知识分享小能手2 小时前
SQL Server 2019入门学习教程,从入门到精通,SQL Server 2019 事务和锁 — 语法知识点及使用方法详解(13)
数据库·学习·sqlserver
之歆2 小时前
iSCSI + GFS2 + cLVM 共享存储完全指南
数据库
一个天蝎座 白勺 程序猿3 小时前
KingbaseES约束机制:数据迁移中的数据完整性保障
开发语言·数据库·kingbase·kingbasees
软件派3 小时前
数据库技术探秘:JDBC、ODBC、CDC与LOAD的深度解析
数据库
cjl_8520083 小时前
[MySQL] MySQL复合查询(多表查询、子查询)
android·mysql·adb
XP62263 小时前
MySQL单表存多大的数据量比较合适
数据库·mysql
是店小二呀3 小时前
MySQL 核心操作:表的CRUD、聚合与分组深度实践
数据库·mysql