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
语句显示分析信息,指示在当前会话过程中执行的语句的资源使用情况
。
从 MySQL 5.6.7 开始不推荐使用这些语句;希望它们在未来的 MySQL 版本中被删除。改用 性能模式 ;请参阅 第 22.18.1 节,“使用性能模式查询分析”。
要控制分析,请使用
profiling
默认值为 0 ( OFF
) 的会话变量。profiling
通过设置为 1 或启用分析ON
:
mysql> SET profiling = 1;
SHOW PROFILES
显示发送到服务器的最新语句的列表。列表的大小由
profiling_history_size
会话变量控制,默认值为 15。最大值为 100。将值设置为 0 具有禁用分析的实际效果。
SHOW
PROFILE
除了and
之外的所有语句都进行了分析SHOW
PROFILES
,因此您在分析列表中找不到这些语句。分析了格式错误的语句。例如,SHOW PROFILING
是一个非法语句,如果您尝试执行它会发生语法错误,但它会显示在分析列表中。
SHOW PROFILE
显示有关单个语句的详细信息。如果没有该子句,输出与最近执行的语句有关。如果
包含,则显示 statement 的信息。的值对应于
显示的值
。
FOR
QUERY
n
FOR QUERY
n
SHOW PROFILE
n
n
Query_ID
SHOW PROFILES
可以给出
该子句以将输出限制为行。如果
给出,可以将输出行添加到完整的行集中。
LIMIT
row_count
row_count
LIMIT
OFFSET
offset
offset
默认情况下,SHOW PROFILE
显示
Status
和Duration
列。这些Status
值类似于
State
显示的值
SHOW PROCESSLIST
,尽管对于某些状态值的两个语句的解释可能存在一些细微差异(请参阅
第 8.14 节,“检查服务器线程(进程)信息”)。
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()
系统调用的值,NULL
在不支持该调用的系统(例如 Windows)上返回。此外,分析是针对每个进程而不是每个线程。这意味着服务器内线程上的活动而不是您自己的线程可能会影响您看到的计时信息。
分析信息也可从
INFORMATION_SCHEMA
PROFILING
表中获得。请参阅
第 21.3.17 节,“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;