道教网站符咒法事网

Mysql性能优化(三):法事上表

精选    道教网    2022-10-27    131

免费测运势 免费批八字:

免费测算批八字.jpg

师父微信: master8299


如何对一条查询语句进行性能分析法事上表,必不可少的要使用的是explain,explain的意思是执行计划;那接下来我们就详细讲明一下explain的返回结果;

一、explain的使用方法

explain select语句;

例如:explain select from stuInfoA;

返回的结果如下图:

新梦想技术分享

结果讲明:

id:是select 的标识符法事上表,表示select 语句的执行顺序;如果该select语句有嵌套查询,则explain会有多行结果返回,也就会有多个id,id的数字越大表示该select子句越先执行;如果数字相同,则按从上到下的顺序执行;

select_type: select_type会根据不一样的SQL语句返回不一样的结果;它有以下返回结果:

SIMPLE:表示不需要union操作或者不包含子查询的简单select语句法事上表,如果有连接查询,外层的查询为simple,且只有一个;

primary:一个需要union操作或者含有子查询的select法事上表,位于最外层的单位查询的select_type即为primary,且只有一个;

union:union连接的多个select查询法事上表,第一个查询是derived派生表,除了第一个表外,第二个以后的表的select_type都是union;

dependent union:与union一样法事上表,出现在union或union all中;取决于外部查询的结果;

union result:包含union的结果集法事上表,在union和union all语句中,因为他不需要参与查询,结果中的id字段为null;

subquery: 除了from子句中包含的子查询外法事上表,其他地方出现的子查询都可能是subquery,讲白了就是子查询;

dependent subquery:与dependent union类似法事上表,表示这个subquery的查询要受到外部表查询的影响 ;

derived:表示派生表;

table: 显示查询的时候涉及的表法事上表,如果是临时表,则显示临时表,临时表用表示;

type: 表示SQL语句的性能从好到差:system,const,eq_ref,ref,fulltext,ref_or_null,unique_subquery,index_subquery,range,index_merge,index,all;

展开全文

如果显示的是all法事上表,则表示该SQL语句进行的是全表扫描,没有使用index,那该SQL语句的性能是最差的,除了all之外,其它的type都可以使用到索引;

system: 表示表中只有一行数据或者是空表法事上表,且只能用于myisam和memery表;

const:表示使用唯一索引或者主键;

eq_ref: 表示驱动表只返回一行数据法事上表,且这一行数据是第二个表的主键或者唯一索引,且必须为not null;唯一索引和主键是多列时,只有所有的列都用作比较时,才会出现eq_ref;

fulltext: 全文索引检索法事上表,全文索引的优先级很高,如果全文索引和普通索引同时存在时,mysql不管代价,优先选择使用全文索引;

index:索引全表扫描法事上表,把索引从头到尾扫一遍;

all: 表示全表扫描数据文件法事上表,再从server层进行过滤返回符合要求的记录;

possible_keys: 查询可能使用到的索引都会在这里列出来

key:查询真正使用到的索引;

key_len: 用于处理查询的索引长度法事上表,如果是单列索引,那就是整个索引的长度;如果是多个索引,只会列出使用到了多少个列的索引,没有使用到的列不会计算进去;

ref: 如果使用的常数等值查询法事上表,这里会显示const,如果是连接查询,被驱动表的执行计划这里会显示驱动表的关联字段,如果是条件使用了表达式或者函数,或者条件列发生了内部隐式转换,这里显示为func;

rows: 执行计划估算的扫描行数法事上表,不是精确值;

extra: 返回的值

distinct : 表示查询的时候使用法事上表了distinct关键字;

no tables used: 不带from子句或者 from dual查询;

using filesort : 排序时无法使用到索引时法事上表,常见于order by 和 group by 语句中;

using index: 查询时不需要回表中查询法事上表,直接通过索引就可以获取查询的数据;

using intersect: 表示使用and 的各个索引的条件时法事上表,该信息表示是从处理结果获取交集;

using where:表示存储引擎返回的记录并不是所有的都满足查询条件法事上表,需要在server层进行过渡;

以上就是explain的返回结果详细讲明法事上表,type 是最能讲明SQL的性能好坏;其它的项都用来辅助进行SQL调优的项;

本文链接:https://daojiaowz.com/index.php/post/73809.html

转载声明:本站发布文章及版权归原作者所有,转载本站文章请注明文章来源!

上一篇   下一篇

相关文章