你真的知道怎么优化SQL吗
数据库  /  管理员 发布于 5年前   197
简介
虽然使用Explain不能够马上调优我们的SQL,它也不能给予我们一些调整建议,但是它能够让我们了解MySQL 优化器是如何执行SQL 语句的
通过Explain,我们可以分析出以下结果:
Explain命令的用法十分简单, 在 select语句前加上 Explain 就可以了, 例如:
explain select * from user;
它的结果主要包含以下字段
id、select_type、table、partitions、type、possible_keys、key、ref、rows、filtered、extra
接下来我们来看一下各个字段的含义
id 查询序列号
加载表的顺序
连接查询各个表的加载顺序是相同的,所以都为1
包含子查询的时候,先执行子查询,所以user表的id值最大
select_type 查询类型
常用取值有:
table查询涉及的表或衍生表
type查询类型
通过 type 字段, 我们可以判断此次查询是全表扫描还是索引扫描等,type 常用的取值有:
system:表只有一条数据
const:针对主键或唯一索引的等值查询扫描, 简单理解为一次读取就获取到了数据,例如下面这个主键索引的查询
eq_ref:唯一性索引扫描,对于每个索引键,表中只有一条记录与之匹配。常见于主键或唯一索引扫描
ref:非唯一性索引扫描,返回匹配某个单独值的所有行
range:表示使用索引范围查询,例如=、<>、>、>=、<、<=、IS、 NULL、<=>、BETWEEN、IN等
index: 所要查询的数据直接在索引树中就可以获取到, 而不需要扫描数据,例如:
ALL: 表示全表扫描, 这个类型的查询是性能最差的查询
type 类型的性能比较
通常来说, 不同的 type 类型的性能关系如下:
ALL < index < range < ref < eq_ref < const < system
possible_keys查询时能够使用到的索引.
possible_keys 表示 MySQL 在查询时, 能够使用到的索引. 注意并不是一定用,实际使用是由 由 key 字段决定
key 查询使用的索引
此字段是 MySQL 在当前查询时所真正使用到的索引.
key_len使用索引的字节数
这个字段可以评估组合索引是否完全被使用, 或只有最左部分字段被使用到.
rows MySQL估算要查找到结果集需要扫描读取的数据行数
Extra额外的信息
常见的有以下几种内容:
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对AIDI的支持。
122 在
学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..123 在
Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..原梓番博客 在
在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..博主 在
佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..1111 在
佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..
Copyright·© 2019 侯体宗版权所有·
粤ICP备20027696号