mysql 如何查看sql语句执行时间和效率--EXPLAIN

一、开启慢查询日志捕获慢SQL

  • 查询mysql是否开启慢日志捕获:SHOW VARIABLES LIKE ‘%slow_query_log%’;

如果还没开启的话,开启:SET GLOBAL slow_query_log=1;

  • 查看慢查询的时间阙值:SHOW GLOBAL VARIABLES LIKE ‘%long_query_time%’;

可以根据实际情况去调整时间:SET GLOBAL long_query_time=2;

  • 查询多少SQL超过了慢查询时间的阙值: SHOW GLOBAL STATUS LIKE ‘%Slow_queries%’;

  • 使用MySQL提供的日志分析工具mysqldumpslow,获取差慢SQL

举例:
–获取慢日志中最多的10个SQL
./mysqldumpslow -s r -t 10 /PATH/TO/慢日志文件
–获取按照时间排序的前10条里面含有左连接的查询语句
mysqldumpslow -s t -t 10 -g “left join” 慢日志文件

二、慢查询

慢sql大部分情况都是查询语句。
慢查询主要体现在慢上,通常意义上来讲,只要返回时间大于 >1 sec上的查询都可以称为慢查询。

三、MySQL Explain详解

type

type所显示的是查询使用了哪种类型,type包含的类型包括如下图所示的几种:

从最好到最差依次是:

system > const > eq_ref > ref > range > index > all

一般来说,得保证查询至少达到range级别,最好能达到ref。

相关推荐

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
©️2022 CSDN 皮肤主题:技术黑板 设计师:CSDN官方博客 返回首页

打赏作者

tester_sz

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

¥2 ¥4 ¥6 ¥10 ¥20
输入1-500的整数
余额支付 (余额:-- )
扫码支付
扫码支付:¥2
获取中
扫码支付

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

打赏作者

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

抵扣说明:

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

余额充值