如何对一条查询语句进行性能分析,必不可少的要使用的是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调优的项;
热搜
相关推荐
-
试点城市名单公示 郑州、开封入选 中央财政将拨款
极目新闻 600跟贴
-
1斤315元 水果新“刺客”销售暴涨 产区多在山东四川
大象新闻 781跟贴
-
保时捷女销冠来汉领取“特别贡献奖”:去年卖出192台车连续三年蝉联销冠,超60%是女顾客,今年没有定目标
极目新闻 1225跟贴
-
实探“抢猪肉”风波中的株洲小村:村民否认抢猪肉,对背上骂名感到憋屈,组织方称很内疚正配合调查
极目新闻 1044跟贴
-
车企老总称U23重庆球员夺冠开新车
极目新闻 2545跟贴
-
全网寻鞋!男子坐卧铺时鞋被穿错,一只斯凯奇变Prada:新鞋第一次穿就丢了,希望能找回
鲁中晨报 133跟贴
-
刚上架就秒空,99元涨到396元!被戏称为“打工治愈神器”,网友:到底是谁在买
环球网资讯 355跟贴
-
动车组专家:我国旅客列车室内二氧化碳浓度标准限值为2500ppm,限值内浓度对健康无影响
澎湃新闻 1165跟贴
-
观察|越共十四大闭幕,越南小心确立“速度与克制”间平衡
澎湃新闻 68跟贴
-
把医疗AI禁锢在严肃区间:百川M3 Plus首创证据锚定,幻觉率2.6%
量子位
-
多省份公布去年结婚登记数据
第一财经资讯 420跟贴
-
U23国足决赛前剪了新发型
央视新闻 596跟贴
-
最高优惠2500元 iPhone Air开启苹果史上最大促销
澎湃新闻 193跟贴
-
日本U23主帅:中国队防守非常出色
北京日报客户端 465跟贴
-
山东挺起工业硬脊梁
人民网 159跟贴
-
海霞,哽咽发言
上观新闻 120跟贴
-
卢拉宣布巴西将对中国公民实施免签政策
财联社 5跟贴
-
多地中小学取消“期末统考”引热议
澎湃新闻 28跟贴 -
多地将器官捐献纳入“见义勇为”评定,专家称概念扩展需审慎
澎湃新闻 6跟贴
-
“马茅”市场价报2250元,溢价率不如“蛇茅”,有代购放弃溢价收取固定代购费
红星资本局 30跟贴
热门跟贴