mysql优化--explain

explain执行计划包含的信息:

id select_type table type possible_keys key key_len ref rows

id:表的读取顺序

多表查询,id相同,执行顺序由上至下

子查询,id不同,id序号递增,id值越大越显先被执行,

select_type:数据读取操作的操作类型

simple查询中不包含子查询或union
primary查询中若包含任何复杂的子部分,则最外层的标被标记
subqueryselect和where的子查询
derivedfrom中的子查询
union第二个select出现在union之后
union result从union获取结果的select

type:显示查询使用了何种类型

执行效率从好到差的顺序:system>const>eq_ref>ref>range>index>ALL

system:表中只有一条记录

const:表示通过索引一次就找到了

eq_ref:主键索引或唯一索引的所有值被作为连接使用,最多只会返回一条符合记录的数据,所以这种类型常出现在多表查询中

ref:非唯一性索引扫描,返回匹配某个单独值的所有行

range:指定了范围的查找

index:全表扫描,与all的区别是使用了索引 

possible_keys:显示可能应用在查询字段中的索引,一个或多个值,但不一定被实际使用

key:实际用到的索引,如果为NULL,则没有使用索引

key_len:索引字段的最大可能长度,并非实际长度,即ken_len是根据表的定义计算得到

怎么通过explain关键字看SQL语句的性能? - 知乎文章已收录Github精选,欢迎Star:https://github.com/yehongzhi前言在MySQL中,我们知道加索引能提高查询效率,这基本上算是常识了。但是有时候,我们加了索引还是觉得SQL查询效率低下,我想看看 有没有使用到索…https://zhuanlan.zhihu.com/p/341595489

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值