explain字段详解

本文详细解释了MySQL的EXPLAIN命令如何揭示SQL语句的执行计划,包括不同类型的查询(如SIMPLE、PRIMARY等)、关联类型(如ref、index等)、以及如何通过设置优化开关查看更详细的计划。讲解了各种查询结构和执行效率分析。

XPLAIN适用于 SELECT, DELETE, INSERT, REPLACE, 和 UPDATE语句。

当EXPLAIN与可解释的语句一起使用时,MySQL 会显示来自优化器的有关语句执行计划的信息。也就是说,MySQL 解释了它将如何处理该语句,包括有关表如何连接以及连接顺序的信息。

因为MySQL底层有SQL优化,因此在一些执行计划查看特定的字段值需要关闭部分优化,具体的优化参数可以参考MySQL 官方文档

set session optimizer_switch='derived_merge=off';  -- 关闭派生表合并优化

查看SQL的执行计划,需要在SQL前加上explain关键字,具体如下:

explain select * from user_role 

执行计划字段描述 

id

ID编号是select的序列号,SQL中有多少select语句就存在多少ID,相同编号执行顺序由上而下,不同编号,值越大优先级越高,如果ID为空,则最后执行

explain select * from `user_role` where user_id IN (select id from `user` where name ='a');

explain select * from  (select remark from `user_role`) a;

explain select * from (select id from `user` union  select user_id from `user_role`) temp;

select_type

  • SIMPLE

简单查询,不包含子查询或者union

explain select * from `user` wher
评论 1
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值