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

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





