MySQL show profile指令分析SQL耗时

show profile指令分析SQL

Mysql从5.0.37版本开始增加了对 show profiles 和 show profile 语句的支持。show profiles 能够在做SQL优化时帮助我们了解时间都耗费到哪里去了

通过 have_profiling 参数,能够看到当前MySQL是否支持profile:

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-qS58HWTn-1614933728005)(E:/黑马/MySQL高级/资料-MySQL高级教程/MySQL 高级 - day-02/文档/assets/1552488401999.png)]

默认profiling是关闭的,0表示未开启,可以通过set语句在Session级别开启profiling

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-V4sHUdES-1614933728007)(E:/黑马/MySQL高级/资料-MySQL高级教程/MySQL 高级 - day-02/文档/assets/1552488372405.png)]

set profiling=1; /*开启 profiling 开关*/

通过profile,我们能够更清楚地了解SQL执行的过程

首先,我们可以执行一系列的操作,如下图所示:

show databases;

use db01;

show tables;

select * from tb_item where id < 5;

select count(*) from tb_item;

执行完上述命令之后,再执行 show profiles 指令, 来查看SQL语句执行的耗时:

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-RgKVHmaK-1614933728008)(图片/3. SQL语句执行分析/image-20210305163039180.png)]

通过 show profile for query query_id 语句可以查看该SQL执行过程中每个线程的状态和消耗的时间

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-N7vZI4Q0-1614933728013)(E:/黑马/MySQL高级/资料-MySQL高级教程/MySQL 高级 - day-02/文档/assets/1552489053763.png)]

Tips :
	Sending data 状态表示MySQL线程开始访问数据行并把结果返回给客户端的过程,而不仅仅是返回给客户端的过程。由于在Sending data状态下,MySQL线程往往需要做大量的磁盘读取操作,所以经常是整各查询中耗时最长的状态。

在获取到最消耗时间的线程状态后,MySQL支持进一步选择all、cpu、block io 、context switch、page faults等明细类型查看MySQL在使用什么资源上耗费了过高的时间。

例如,选择查看CPU的耗费时间 :

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-XHHZJIee-1614933728014)(E:/黑马/MySQL高级/资料-MySQL高级教程/MySQL 高级 - day-02/文档/assets/1552489671119.png)]

字段含义
Statussql 语句执行的状态
Durationsql 执行过程中每一个步骤的耗时
CPU_user当前用户占有的cpu
CPU_system系统占有的cpu
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Nice2cu_Code

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值