我的编程空间,编程开发者的网络收藏夹
学习永远不晚

explain中怎么查看执行计划

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

explain中怎么查看执行计划

explain中怎么查看执行计划,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。

explain内容

查看user全表查询的执行计划:

mysql> explain select * from user;

 explain中怎么查看执行计划

id

id表示select查询语句的执行顺序或者是操作表的执行顺序。

id的值有二种情况:

  1. 鸿蒙官方战略合作共建——HarmonyOS技术社区

  2. id相同,表示执行的顺序是由上至下

  3. id不同,id的序号会是递增的,id的值越大表示优先级越高,越先被执行。

select_type

select_type表示查询类型,它的值域为:SIMPLE、PRIMARY、SUBQUERY、DERIVED、UNION、UNION  RESULT。

  • SIMPLE:简单的查询,不包含子查询和UNION。

  • PRIMARY:如果查询的语句中包含了复杂的子查询,那么最外层的查询被标记为PRIMARY。

  • SUBQUERY:select或者where中的子查询。

  • DERIVED:from列表中的子查询生成的衍生表查询。

  • UNION:联合查询。

  • UNION RESULT:从UNION表获取结果的查询。

table

数据行是从哪个表获取的。

type

表示查询使用了哪种类型,它的值域:ALL、index、range、ref、eq_ref、const、system。这是我们优化时重点关注的一个指标。

从最好到最差排序:

system>const>eq_ref>ref>range>index>ALL。

阿里巴巴SQL优化规范:

  • 【推荐】 SQL性能优化的目标:至少要达到 range 级别,要求是ref级别,如果可以是const最好。

  • 说明:

  • 1)const 单表中最多只有一个匹配行(主键或者唯一索引),在优化阶段即可读取到数据。

  • 2)ref 指的是使用普通的索引(normal index)。

  • 3)range 对索引进行范围检索。

system:表中只有一行记录的查询,类似系统表。

eq_ref:多表时唯一索引扫描,对于每一个索引,表中只有一行记录相匹配。

index:索引物理文件全扫描,速度比较慢,比全表扫描性能好一点。

ALL:全表扫描。

possible_keys

可能应用在这个表的索引,可以会一个或者多个,不一定是实际查询使用的索引。

key

查询中实际使用的索引,如果为null表示没有使用索引。

如果是覆盖索引,则只显示在key中。

key_len

表示索引字段的最大可能长度,并不是实际的长度,它是根据表定义得到的,而不是通过表检索得到的。长度越短越好。

ref

表示索引的哪一列被使用了,可能是个常数。哪些列或者常量被用于查找索引列上的值。

rows

根据表的信息和索引使用情况,大致估算的查找到所需的记录需要扫描的行数。越小越好。

Extra

扩展信息。

阿里巴巴SQL优化规范:

  • 【推荐】利用覆盖索引来进行查询操作,避免回表。

  • 说明:如果一本书需要知道第11章是什么标题,会翻开第11章对应的那一页吗?目录浏览一下就好,这个目录就是起到覆盖索引的作用。

  • 正例:能够建立索引的种类分为主键索引、唯一索引、普通索引三种,而覆盖索引只是一种查询的一种效果,用explain的结果,extra列会出现:using  index。

这里提到了覆盖索引,extra列会出现using index。

extra还有其他比较重要的信息:

using filesort:用到了外部的索引排序,即MySQL无法利用索引完成排序。

using temptory:使用了临时表。

using where:使用了where过滤。

关于explain中怎么查看执行计划问题的解答就分享到这里了,希望以上内容可以对大家有一定的帮助,如果你还有很多疑惑没有解开,可以关注亿速云行业资讯频道了解更多相关知识。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

explain中怎么查看执行计划

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

oracle中怎么查看执行计划

在Oracle中查看执行计划可以通过以下两种方法:1、使用EXPLAIN PLAN语句来生成执行计划:EXPLAIN PLAN FORSELECT * FROM table_name;SELECT * FROM TABLE(DBMS_
oracle中怎么查看执行计划
2024-03-13

怎么查看mysql执行计划

要查看MySQL执行计划,可以使用EXPLAIN关键字。在执行SQL语句之前,将其放在EXPLAIN关键字之前,然后执行该语句。例如:EXPLAIN SELECT * FROM table_name;这将返回一个执行计划,显示MySQL
怎么查看mysql执行计划
2024-04-09

Oracle怎么查看执行计划

在Oracle数据库中,可以使用以下两种方法来查看执行计划:1、使用EXPLAIN PLAN语句:您可以在SQL查询前添加”EXPLAIN PLAN FOR”语句,然后执行该SQL查询,系统会生成执行计划并存储在PLAN_TABLE表中。
Oracle怎么查看执行计划
2024-04-09

MySQL中的执行计划explain

一、用法及定义:  explain为sql的执行计划、在sql前面加上explain关键字即可如:explain select * from tbl_emp;名词解释:  id:【操作表的顺序】    1.id相同,表的执行顺序从上往下依次执行    2.id
MySQL中的执行计划explain
2015-01-30

mysql怎么查看sql执行计划

要查看MySQL中SQL语句的执行计划,可以使用EXPLAIN关键字来获取查询的执行计划。以下是使用EXPLAIN来查看SQL执行计划的步骤:1、打开MySQL客户端或者在命令行中连接到MySQL数据库。2、输入要查询的SQL语句,并在
mysql怎么查看sql执行计划
2024-04-15

PostgreSQL中如何查看执行计划

在 PostgreSQL 中,可以使用 EXPLAIN 命令来查看查询语句的执行计划。执行计划显示了 PostgreSQL 优化器将如何执行查询语句的详细信息,包括使用的索引、连接方法、排序方法等。要查看执行计划,可以在查询语句前加上 E
PostgreSQL中如何查看执行计划
2024-04-09

oracle怎么查看sql历史执行计划

要查看SQL历史执行计划,可以使用以下方法:使用Oracle的动态性能视图:通过查询v$sql_plan或v$sql_plan_statistics_all视图可以查看SQL语句的执行计划。可以使用以下SQL语句来查看历史执行计划:SELE
oracle怎么查看sql历史执行计划
2024-04-09

编程热搜

目录