对于 sql 性能的判断,你是否还是通过百度,看看人家的博客,通过别人的回答 做出判断,或是凭自己的一点知识加上猜想呢?如果是,那么你将很被动,百度出来的经验我们无法判断是否正确,如果出了问题,可能就不知道怎么办了 。其实我们完全可以通过分析得到我们想要的答案。
分析需要工具,今天我就给大家介绍两个很厉害的命令,通过它们,你将不用再求百度。
一、 profiling命令:
show profiles是5.0.37之后添加的,要想使用此功能,要确保版本在5.0.37之后。
我们直接上图:

默认情况下,profiling 是关闭的,我们需要手工的打开

打开之后我们就可以使用啦 ,试试看 show profiles

啥也没有? 当然啦,我们还没有开始查询,我查询几条记录试试看。

再show profiles:

我们可以看到 我们查询的历史记录,执行的非常详细的时间。
如果我们想查看更详细的信息当然也是没有任何问题,我们继续往下,比如我想查看 第9条sql:

在这里我们就可以看到这条sql执行的整个过程,我们不再需要猜测,直接可以看到权限验证、打开表,初始化,统计、排序,是否使用临时表等。
当前这条语句比较简单,我们可以看到主要花费的时间是在 sending data上。
二、explain命令
explain与profiling都是用于sql语句的分析,
explain是从整体上进行分析,包括扫描了多少行,是否使用索引,使用了什么索引,是否用到临时表,是否使用了文件排序。
profiling是分析一条sql从开始到结束的各个环节使用的时间。
我们使用explain来分析一条sql语句:

参数说明:
- id:select查询编号,这个不重要
- select_type:查询类型
simple:简单查询、没有子查询
primary:最外面的select,在有子查询的语句中,最外面的select查询就是primary
subquery:子查询
union:union语句的第二个或者说是后面那一个
union result:union的结果
select_type 其实不是很重要。 - table: 表名,使用别名时显示别名
- type:查询性能等级类型(很重要)
system:表仅有一行,这是const类型的特列,平时不会出现,这个也可以忽略不计
const:表最多有一个匹配行,一般是根据主键查,或者唯一索引,达到常量级别,性能很好
eq_ref:通过索引直接定位到某一行,常见于连接查询中
ref: 通过索引,可以直接引用到某些数据行
range:根据索引做范围扫描
index:扫描所有的索引节点
all:全表扫描 - possible key:可能用到的索引
注意:系统估计可能用到几个索引,最终只能用一个。 - key:最终用到的索引
- key_len:使用的索引最大长度
- Extra:详细说明
这两个命令用起来其实也比较简单,对照每个参数的含义 就能对语句做出分析了,希望这篇文章能对大家有所帮助。
欢迎关注微信公众号:shoshana
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
· 一个奇形怪状的面试题:Bean中的CHM要不要加volatile?
· 分享4款.NET开源、免费、实用的商城系统
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
· 上周热点回顾(2.24-3.2)