Explain查看MySql执行计划

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值