暂无图片
暂无图片
暂无图片
暂无图片
暂无图片

MySQL的SQL语句 - 数据库管理语句 - SHOW 语句 - SHOW PROFILE 语句

林员外聊编程 2021-04-12
184
SHOW PROFILE 语句
 
SHOW PROFILE [type [, type] ... ]
[FOR QUERY n]
[LIMIT row_count [OFFSET offset]]


type: {
ALL
| BLOCK IO
| CONTEXT SWITCHES
| CPU
| IPC
| MEMORY
| PAGE FAULTS
| SOURCE
| SWAPS
}
 
SHOW PROFILE SHOW PROFILES 语句显示分析信息,这些信息指示在当前会话过程中执行的语句的资源使用情况。
 
注意
 
SHOW PROFILE SHOW PROFILES 语句已弃用;预计会在将来的 MySQL 版本中删除它们。请在 Performance Schema 中查询相关信息。
 
要控制分析,请使用 profiling 会话变量,该变量的默认值为 0OFF)。通过将 profiling 设置为 1 ON 启用分析:
 
mysql> SET profiling = 1;
 
SHOW PROFILES 显示发送到服务器的最新语句的列表。列表的大小由 profiling_history_size 会话变量控制,该变量的默认值为 15。最大值为 100。将该值设置为 0 相当于禁用分析。
 
除了 SHOW PROFILE SHOW PROFILES 之外,所有语句都会被分析,因此这2个语句都不会出现在分析列表中。对格式错误的语句也会进行分析。例如,SHOW PROFILING 是一个非法语句,如果您试图执行它,就会出现语法错误,但它会显示在分析列表中。
 
SHOW PROFILE 显示有关单个语句的详细信息。如果没有 FOR QUERY n 子句,则输出保留最近执行的语句。如果包含 FOR QUERY nSHOW PROFILE 将显示语句 n 的信息。n 的值对应于 SHOW PROFILES 显示的 Query_ID 值。
 
LIMIT row_count 子句可用于将输出限制为 row_count 行。如果指定了 LIMIT,还可以添加 OFFSET offset将输出向后偏移 offset 行。

 
默认情况下,SHOW PROFILE 显示 Status Duration 列。Status 值类似于 SHOW PROCESSLIST 显示的 State 值,尽管对于某些状态值,这两个语句的解释可能存在一些细微的差异。
 
可以指定可选 type 值以显示特定的附加信息类型:
 
 ALL 显示所有信息
 
 BLOCK IO 显示块输入和输出操作的计数
 
 CONTEXT SWITCHES 显示自愿和非自愿上下文切换的计数?
 
 CPU 显示用户和系统CPU使用时间
 
 IPC 显示发送和接收的消息计数
 
 MEMORY 当前未实现
 
 PAGE FAULTS 显示主要和次要页面错误的计数
 
 SOURCE 显示源代码中函数的名称,以及函数所在文件的名称和行号
 
 SWAPS 显示交换计数
 
每个会话都启用分析。会话结束时,其分析信息将丢失。
 
mysql> SELECT @@profiling;
+-------------+
| @@profiling |
+-------------+
| 0 |
+-------------+
1 row in set (0.00 sec)


mysql> SET profiling = 1;
Query OK, 0 rows affected (0.00 sec)


mysql> DROP TABLE IF EXISTS t1;
Query OK, 0 rows affected, 1 warning (0.00 sec)


mysql> CREATE TABLE T1 (id INT);
Query OK, 0 rows affected (0.01 sec)


mysql> SHOW PROFILES;
+----------+----------+--------------------------+
| Query_ID | Duration | Query |
+----------+----------+--------------------------+
| 0 | 0.000088 | SET PROFILING = 1 |
| 1 | 0.000136 | DROP TABLE IF EXISTS t1 |
| 2 | 0.011947 | CREATE TABLE t1 (id INT) |
+----------+----------+--------------------------+
3 rows in set (0.00 sec)


mysql> SHOW PROFILE;
+----------------------+----------+
| Status | Duration |
+----------------------+----------+
| checking permissions | 0.000040 |
| creating table | 0.000056 |
| After create | 0.011363 |
| query end | 0.000375 |
| freeing items | 0.000089 |
| logging slow query | 0.000019 |
| cleaning up | 0.000005 |
+----------------------+----------+
7 rows in set (0.00 sec)


mysql> SHOW PROFILE FOR QUERY 1;
+--------------------+----------+
| Status | Duration |
+--------------------+----------+
| query end | 0.000107 |
| freeing items | 0.000008 |
| logging slow query | 0.000015 |
| cleaning up | 0.000006 |
+--------------------+----------+
4 rows in set (0.00 sec)


mysql> SHOW PROFILE CPU FOR QUERY 2;
+----------------------+----------+----------+------------+
| Status | Duration | CPU_user | CPU_system |
+----------------------+----------+----------+------------+
| checking permissions | 0.000040 | 0.000038 | 0.000002 |
| creating table | 0.000056 | 0.000028 | 0.000028 |
| After create | 0.011363 | 0.000217 | 0.001571 |
| query end | 0.000375 | 0.000013 | 0.000028 |
| freeing items | 0.000089 | 0.000010 | 0.000014 |
| logging slow query | 0.000019 | 0.000009 | 0.000010 |
| cleaning up | 0.000005 | 0.000003 | 0.000002 |
+----------------------+----------+----------+------------+
7 rows in set (0.00 sec)
 
注意
 
在某些体系结构上,概要分析只能发挥部分功能。对于依赖 getrusage() 系统调用的值,在不支持该调用的系统(如 Windows)上返回 NULL。此外,分析是按进程而不是按线程进行的。这意味着服务器内线程上的活动(而不是您自己的线程)可能会影响您看到的计时信息。
 
分析信息也可以从 INFORMATION_SCHEMA PROFILING 表中获得。例如,以下查询是等效的:
 
SHOW PROFILE FOR QUERY 2;


SELECT STATE, FORMAT(DURATION, 6) AS DURATION
FROM INFORMATION_SCHEMA.PROFILING
WHERE QUERY_ID = 2 ORDER BY SEQ;
 
 
 
 
 
 
 
官方文档:
https://dev.mysql.com/doc/refman/8.0/en/show-profile.html
 

文章转载自林员外聊编程,如果涉嫌侵权,请发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。

评论