Documentation Home
MySQL 8.4 Reference Manual
Related Documentation Download this Manual
PDF (US Ltr) - 39.8Mb
PDF (A4) - 39.9Mb
Man Pages (TGZ) - 257.9Kb
Man Pages (Zip) - 364.9Kb
Info (Gzip) - 4.0Mb
Info (Zip) - 4.0Mb


15.7.7.31 显示配置文件语句

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 语句显示了在当前会话中执行的语句的资源使用信息。

Note

SHOW PROFILE 和 SHOW PROFILES 语句已弃用,预计将在未来的 MySQL 发布中删除。请使用 性能 Schema,详见 第 29.19.1 节,“使用性能 Schema 查询 profiling”

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

mysql> SET profiling = 1;

SHOW PROFILES 显示最近执行的语句列表。列表的大小由 profiling_history_size 会话变量控制,该变量的默认值为 15。最大值为 100。将该值设置为 0 将实际上禁用 profiling。

所有语句都被 profile,除了 SHOW PROFILESHOW PROFILES,因此这两个语句不在 profile 列表中。 malformed 语句也被 profile。例如,SHOW PROFILING 是一个非法语句,如果你尝试执行它,将出现语法错误,但它将出现在 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显示StatusDuration列。Status值类似于SHOW PROCESSLIST中的State值,虽然可能有一些 minor 的差异在解释某些状态值时(见第10.14节,“Examining Server Thread (Process) Information”)。

可以指定可选的type值以显示特定的附加信息:

  • ALL显示所有信息

  • BLOCK IO显示块输入和输出操作的计数

  • CONTEXT SWITCHES显示自愿和非自愿上下文切换的计数

  • CPU显示用户和系统 CPU 使用时间

  • IPC显示消息发送和接收的计数

  • MEMORY当前未实现

  • PAGE FAULTS显示主要和次要页面故障的计数

  • SOURCE显示来自源代码的函数名称,及其在文件中的名称和行号

  • SWAPS显示交换计数

profiling 是每个会话的。会话结束时, profiling 信息将被丢弃。

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)
Note

profiling 只在部分架构上可用。对于依赖于getrusage()系统调用的一些值,NULL将在不支持该调用系统,如 Windows 时返回。此外,profiling 是每个进程,而不是每个线程。这意味着在服务器中的其他线程活动可能会影响您看到的时间信息。

profiling 信息也可以从INFORMATION_SCHEMA PROFILING表中获取。见第28.3.24节,“The INFORMATION_SCHEMA PROFILING Table”。例如,以下查询是等效的:

SHOW PROFILE FOR QUERY 2;

SELECT STATE, FORMAT(DURATION, 6) AS DURATION
FROM INFORMATION_SCHEMA.PROFILING
WHERE QUERY_ID = 2 ORDER BY SEQ;