mysql查询正在执行的语句

Posted 满血复活的回来写代码

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了mysql查询正在执行的语句相关的知识,希望对你有一定的参考价值。

排查问题时,需要查看正在执行的SQL,可以用如下两种方式进行查看。

1: 使用show processlist,但是有个弊端,就是只能查看正在执行的sql语句,对应历史记录,查看不到。好处是不用设置,不会保存。

1 -- use information_schema;
2 -- show processlist;
3 或者:
4 -- select * from information_schema.`PROCESSLIST` where info is not null;

2、开启日志模式。(可以记录)

1 -- 1、设置
2 -- SET GLOBAL log_output = ‘TABLE‘;  SET GLOBAL general_log = ‘ON‘;
3 -- SET GLOBAL log_output = ‘TABLE‘;  SET GLOBAL general_log = ‘OFF‘;
4 
5 -- 2、查询
6 SELECT * from mysql.general_log ORDER BY    event_time DESC
7 
8 -- 3、清空表(delete对于这个表,不允许使用,只能用truncate)
9 -- truncate table mysql.general_log;

注意:truncate 删除该表不会产生碎片。收集完成之后,需要及时关闭日志模式

以上是关于mysql查询正在执行的语句的主要内容,如果未能解决你的问题,请参考以下文章

mysql如何查询SQL中哪些语句执行最占用CPU?

mysql 查询正在执行的进程-亲试ok

MySql使用show processlist查看正在执行的Sql语句

sql语句中嵌套时候用in 和=有啥区别

使用 PHP 执行多个 MYSQL 查询

db2 怎样查一个sql连接执行过的所有语句?