最常用方法是执行 SHOW PROCESSLIST 命令,可查看所有连接的线程ID、用户、主机、数据库、命令类型、运行时间、状态及SQL语句;管理员可用 SHOW FULL PROCESSLIST 或查询 information_schema.PROCESSLIST 视图并过滤,关键状态如 Locked、Sending data 等提示性能问题,必要时用 KILL 终止异常线程。
要查看 MySQL 当前正在运行的 SQL 语句及其执行状态,最常用、最直接的方法是使用 SHOW PROCESSLIST 命令。它能列出所有客户端连接及每个连接正在执行的语句、状态、耗时等关键信息。
在 MySQL 客户端(如 mysql 命令行、Navicat、DBeaver 等)中执行:
SHOW PROCESSLIST;
该命令返回结果包含以下重要列:
SHOW FULL PROCESSLIST 可显示完整语句)普通用户可能只能看到自己的会话,而

SHOW FULL PROCESSLIST;
或查询性能视图(MySQL 5.7+,推荐):
SELECT id, user, host, db, command, time, state, info FROM information_schema.PROCESSLIST ORDER BY time DESC;
这个方式支持 WHERE 过滤(比如查运行超 60 秒的 SQL):
SELECT * FROM information_schema.PROCESSLIST WHERE TIME > 60 AND COMMAND = 'Query';
State 列反映 SQL 执行所处的内部阶段,常见且需关注的状态有:
若发现某条 SQL 卡死或消耗过高资源,可通过其 Id 终止:
KILL 12345;
其中 12345 是对应线程的 Id。注意:
– KILL 只中断语句执行,不回滚事务(除非是自动提交模式)
– 若状态为 Waiting for table metadata lock,往往需先 KILL 掉持有锁的长事务线程
– 生产环境执行前建议确认影响范围