explain命令用于分析mysql查询的执行计划,找出性能低下的原因。其输出包含:表别名查询类型表名连接类型索引使用情况估计返回行数过滤百分比其他信息

MySQL EXPLAIN用法

EXPLAIN是MySQL中一个重要的工具,用于分析SQL查询的执行计划。通过使用EXPLAIN,可以了解查询是如何执行的,并可以找出查询性能低下的原因。

用法

使用EXPLAIN的语法如下:

EXPLAIN [EXTENDED] [FORMAT=JSON] query;
登录后复制
  • EXTENDED:扩展输出,显示更多信息。
  • FORMAT=JSON:将结果输出为JSON格式。

输出

EXPLAIN的输出包含以下信息:

  • id:查询中表的别名。
  • select_type:查询类型,如SIMPLE、UNION等。
  • table:表名。
  • partitions:分区信息。
  • type:连接类型,如index、ALL等。
  • possible_keys:可以使用但未使用的索引。
  • key:实际使用的索引(如果存在)。
  • key_len:索引长度。
  • ref:用于连接表的行。
  • rows:估计返回的行数。
  • filtered:过滤掉的百分比。
  • Extra:其他信息。

如何使用

为了使用EXPLAIN,只需在查询前添加EXPLAIN命令即可。例如:

EXPLAIN SELECT * FROM users WHERE name = 'John';
登录后复制

示例

以下是一个EXPLAIN输出的示例:

mysql> EXPLAIN SELECT * FROM users WHERE name = 'John';
+----+-------------+-------+------+---------------+----------+-------+------+------+-----------------------------+
| id | select_type | table | type | possible_keys | key      | key_len | ref  | rows | Extra                       |
+----+-------------+-------+------+---------------+----------+-------+------+------+-----------------------------+
|  1 | SIMPLE      | users | ref  | name          | name     | 767     | const |    1 | Using where; Using index |
+----+-------------+-------+------+---------------+----------+-------+------+------+-----------------------------+
登录后复制

从输出中,我们可以看到:

  • 该查询使用了索引(type=ref)。
  • 使用了name列的索引(key=name)。
  • 索引长度为767字节(key_len=767)。
  • 估计返回1行(rows=1)。

通过这些信息,我们可以确定查询的执行计划是高效的。

以上就是mysql explain的用法的详细内容,更多请关注慧达安全导航其它相关文章!

点赞(0)

评论列表 共有 0 条评论

暂无评论
立即
投稿
发表
评论
返回
顶部