文档首页
MySQL 9.0 参考手册
相关文档 下载此手册
PDF (US Ltr) - 40.0Mb
PDF (A4) - 40.1Mb
Man Pages (TGZ) - 258.2Kb
Man Pages (Zip) - 365.3Kb
Info (Gzip) - 4.0Mb
Info (Zip) - 4.0Mb


MySQL 9.0 参考手册  /  ...  /  SHOW PROFILE 语句

15.7.7.31 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 PROFILESHOW PROFILES 语句显示配置文件信息,这些信息指示在当前会话期间执行的语句的资源使用情况。

注意

SHOW PROFILESHOW PROFILES 语句已弃用;预计将在将来的 MySQL 版本中删除。请改用 Performance Schema;参见 第 29.19.1 节,“使用 Performance Schema 进行查询分析”.

要控制分析,请使用 profiling 会话变量,该变量的默认值为 0 (OFF)。通过将 profiling 设置为 1 或 ON 来启用分析。

mysql> SET profiling = 1;

SHOW PROFILES 显示最近发送到服务器的一系列语句。列表大小由 profiling_history_size 会话变量控制,其默认值为 15。最大值为 100。将值设置为 0 的实际效果是禁用分析。

SHOW PROFILESHOW PROFILES 之外,所有语句都将被分析,因此这两个语句都不会出现在分析列表中。格式错误的语句将被分析。例如,SHOW PROFILING 是一个非法语句,如果您尝试执行它,则会发生语法错误,但它会显示在分析列表中。

SHOW PROFILE 显示单个语句的详细信息。如果没有 FOR QUERY n 子句,则输出与最近执行的语句相关。如果包含 FOR QUERY n,则 SHOW PROFILE 显示语句 n 的信息。 n 的值对应于 SHOW PROFILES 显示的 Query_ID 值。

LIMIT row_count 子句可用于将输出限制为 row_count 行。如果给出 LIMIT,则可以添加 OFFSET offset 以从完整行集中 offset 行开始输出。

默认情况下,SHOW PROFILE 显示 StatusDuration 列。 Status 值类似于 SHOW PROCESSLIST 显示的 State 值,尽管对于某些状态值,这两个语句的解释可能略有不同(参见 第 10.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() 系统调用的值,在不支持该调用的系统(如 Windows)上,将返回 NULL。此外,分析是按进程进行的,而不是按线程进行的。这意味着服务器中除您自己之外的线程上的活动可能会影响您看到的计时信息。

分析信息也可以从 INFORMATION_SCHEMA PROFILING 表获得。见 第 28.3.24 节,“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;