如何使用
开发运维过程中,经常碰到SQL执行慢的情况,这时候可以通过Explain命令查看执行计划,根据执行计划分析问题进而优化SQL。
Explain用法其实不难,只需要在SQL语句前加上该关键字即可,例如explain select * from user,示例结果如图:
Explain可以用在insert、update、delete、select语句上,通常我们更关注select的使用情况。
字段详情
Explain使用起来简单,但是想要弄懂每个字段的含义和类型却是不太容易,我们需要弄懂每个字段的含义和取值类型,才能清楚的找到需要优化的地方。
执行计划查询结果的字段说明:
以上字段中有几个重点关注字段,说明如下:
1)id 查询标识符:
执行顺序一般按照id由大到小,如果id相同,则按顺序由上至下执行。一般情况下id是正整数,但当存在Union操作时,值可能为NULL。
2)select_type 查询类型:
3)type 连接类型:
优化目标:越往上性能约好,尽可能使用上面的type类型,避免ALL全表扫描。
总 结
对于需要优化的SQL,我们可以用Explain来查看其执行计划。在执行计划中,重点关注type取值,它最能反应出SQL目前的执行效率级别。同时可以结合其他的字段,或者分解每个环节语句,来做更细致的分析。
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/129542.html
摘要:如果语句中使用了子查询集合操作临时表等情况,会给列带来很大的复杂性。会递归执行这些子查询,把结果放在临时表里。查询优化器从中所选择使用的索引。该字段显示了查询优化器通过系统收集的统计信息估算出来的结果集记录条数。 引言 优化SQL,是DBA常见的工作之一。如何高效、快速地优化一条语句,是每个DBA经常要面对的一个问题。在日常的优化工作中,我发现有很多操作是在优化过程中必不可少的步骤。然...
摘要:如果该列是,则没有相关的索引。要想强制使用或忽视列中的索引,在查询中使用或者。这个值强调了语句会导致没有符合条件的行。 写一下Explain记录一下 简单粗暴的记录一下,日常使用Explain是为了查看目标SQL是不是用到了索引,也就是索引的使用情况,但是,没写这篇文章之前我使用Explain全靠猜,写这个的目的也是自己整理学习一下,ok,步入正题 使用场景一般就是这种: 在查询语句之...
阅读 1249·2023-01-11 13:20
阅读 1558·2023-01-11 13:20
阅读 1012·2023-01-11 13:20
阅读 1680·2023-01-11 13:20
阅读 3971·2023-01-11 13:20
阅读 2519·2023-01-11 13:20
阅读 1355·2023-01-11 13:20
阅读 3486·2023-01-11 13:20