要查看 MySQL 当前正在运行的 SQL 语句及其执行状态,最常用、最直接的方法是使用
SHOW PROCESSLIST命令。它能列出所有客户端连接及每个连接正在执行的语句、状态、耗时等关键信息。
使用 SHOW PROCESSLIST 查看实时执行状态
在 MySQL 客户端(如 mysql 命令行、Navicat、DBeaver 等)中执行:
SHOW PROCESSLIST;
该命令返回结果包含以下重要列:
Id:线程唯一标识(即 connection id) User:发起连接的用户名 Host:客户端 IP 和端口 db:当前默认数据库 Command:当前执行的命令类型(如 Query、Sleep、Connect) Time:该线程处于当前状态的秒数(重点关注长时间运行的 Query) State:线程内部执行状态(如 Sending data、Sorting result、Locked、Copying to tmp table 等) Info:正在执行的 SQL 语句(若太长会被截断;用SHOW FULL PROCESSLIST可显示完整语句)
查看更详细/全量的会话信息(需 SUPER 或 PROCESS 权限)
普通用户可能只能看到自己的会话,而管理员可查看全部。若权限足够,推荐使用:
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 值
State 列反映 SQL 执行所处的内部阶段,常见且需关注的状态有:
Sending data:通常表示正在处理 SELECT 并准备发送结果(不一定是慢,但长时间停留可能意味着扫描大量数据或未走索引) Sorting result:正在对结果集排序(可能缺排序字段索引) Creating tmp table:创建了内部临时表(常见于 GROUP BY、DISTINCT、UNION 或大结果集排序) Copying to tmp table:正把数据拷入临时表(性能开销大) Locked:被表锁或元数据锁(MDL)阻塞(尤其在 DDL 操作期间) Waiting for table metadata lock:典型阻塞态,说明有长事务或未提交事务占着 MDL终止异常运行的 SQL(谨慎操作)
若发现某条 SQL 卡死或消耗过高资源,可通过其
Id终止:
KILL 12345;
其中
12345是对应线程的 Id。注意:
– KILL 只中断语句执行,不回滚事务(除非是自动提交模式)
– 若状态为
Waiting for table metadata lock,往往需先 KILL 掉持有锁的长事务线程
– 生产环境执行前建议确认影响范围
