0

0

如何查看当前运行sql_mysql执行状态查询

P粉602998670

P粉602998670

发布时间:2026-01-23 01:09:22

|

964人浏览过

|

来源于php中文网

原创

最常用方法是执行 SHOW PROCESSLIST 命令,可查看所有连接的线程ID、用户、主机、数据库、命令类型、运行时间、状态及SQL语句;管理员可用 SHOW FULL PROCESSLIST 或查询 information_schema.PROCESSLIST 视图并过滤,关键状态如 Locked、Sending data 等提示性能问题,必要时用 KILL 终止异常线程。

如何查看当前运行sql_mysql执行状态查询

要查看 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+,推荐):

Audo Studio
Audo Studio

AI音频清洗工具(噪音消除、声音平衡、音量调节)

下载
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 掉持有锁的长事务线程
– 生产环境执行前建议确认影响范围

相关专题

更多
数据分析工具有哪些
数据分析工具有哪些

数据分析工具有Excel、SQL、Python、R、Tableau、Power BI、SAS、SPSS和MATLAB等。详细介绍:1、Excel,具有强大的计算和数据处理功能;2、SQL,可以进行数据查询、过滤、排序、聚合等操作;3、Python,拥有丰富的数据分析库;4、R,拥有丰富的统计分析库和图形库;5、Tableau,提供了直观易用的用户界面等等。

684

2023.10.12

SQL中distinct的用法
SQL中distinct的用法

SQL中distinct的语法是“SELECT DISTINCT column1, column2,...,FROM table_name;”。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

323

2023.10.27

SQL中months_between使用方法
SQL中months_between使用方法

在SQL中,MONTHS_BETWEEN 是一个常见的函数,用于计算两个日期之间的月份差。想了解更多SQL的相关内容,可以阅读本专题下面的文章。

348

2024.02.23

SQL出现5120错误解决方法
SQL出现5120错误解决方法

SQL Server错误5120是由于没有足够的权限来访问或操作指定的数据库或文件引起的。想了解更多sql错误的相关内容,可以阅读本专题下面的文章。

1117

2024.03.06

sql procedure语法错误解决方法
sql procedure语法错误解决方法

sql procedure语法错误解决办法:1、仔细检查错误消息;2、检查语法规则;3、检查括号和引号;4、检查变量和参数;5、检查关键字和函数;6、逐步调试;7、参考文档和示例。想了解更多语法错误的相关内容,可以阅读本专题下面的文章。

359

2024.03.06

oracle数据库运行sql方法
oracle数据库运行sql方法

运行sql步骤包括:打开sql plus工具并连接到数据库。在提示符下输入sql语句。按enter键运行该语句。查看结果,错误消息或退出sql plus。想了解更多oracle数据库的相关内容,可以阅读本专题下面的文章。

717

2024.04.07

sql中where的含义
sql中where的含义

sql中where子句用于从表中过滤数据,它基于指定条件选择特定的行。想了解更多where的相关内容,可以阅读本专题下面的文章。

577

2024.04.29

sql中删除表的语句是什么
sql中删除表的语句是什么

sql中用于删除表的语句是drop table。语法为drop table table_name;该语句将永久删除指定表的表和数据。想了解更多sql的相关内容,可以阅读本专题下面的文章。

419

2024.04.29

菜鸟裹裹入口以及教程汇总
菜鸟裹裹入口以及教程汇总

本专题整合了菜鸟裹裹入口地址及教程分享,阅读专题下面的文章了解更多详细内容。

0

2026.01.22

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
MySQL 教程
MySQL 教程

共48课时 | 1.9万人学习

MySQL 初学入门(mosh老师)
MySQL 初学入门(mosh老师)

共3课时 | 0.3万人学习

简单聊聊mysql8与网络通信
简单聊聊mysql8与网络通信

共1课时 | 805人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号