资讯专栏INFORMATION COLUMN

Explain查看MySql执行计划

IT那活儿 / 2246人阅读
Explain查看MySql执行计划

点击上方“IT那活儿”,关注后了解更多内容,不管IT什么活儿,干就完了!!!




如何使用



开发运维过程中,经常碰到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目前的执行效率级别。同时可以结合其他的字段,或者分解每个环节语句,来做更细致的分析。




本文作者:孙涛涛

本文来源:IT那活儿(上海新炬王翦团队)

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/129542.html

相关文章

  • 自制小工具大大加速MySQL SQL语句优化(附源码)

    摘要:如果语句中使用了子查询集合操作临时表等情况,会给列带来很大的复杂性。会递归执行这些子查询,把结果放在临时表里。查询优化器从中所选择使用的索引。该字段显示了查询优化器通过系统收集的统计信息估算出来的结果集记录条数。 引言 优化SQL,是DBA常见的工作之一。如何高效、快速地优化一条语句,是每个DBA经常要面对的一个问题。在日常的优化工作中,我发现有很多操作是在优化过程中必不可少的步骤。然...

    Hujiawei 评论0 收藏0
  • 【渣渣程序员我不是DBA】MySQLExplain记录一下

    摘要:如果该列是,则没有相关的索引。要想强制使用或忽视列中的索引,在查询中使用或者。这个值强调了语句会导致没有符合条件的行。 写一下Explain记录一下 简单粗暴的记录一下,日常使用Explain是为了查看目标SQL是不是用到了索引,也就是索引的使用情况,但是,没写这篇文章之前我使用Explain全靠猜,写这个的目的也是自己整理学习一下,ok,步入正题 使用场景一般就是这种: 在查询语句之...

    Jokcy 评论0 收藏0

发表评论

0条评论

IT那活儿

|高级讲师

TA的文章

阅读更多
最新活动
阅读需要支付1元查看
<