千锋教育-做有情怀、有良心、有品质的职业教育机构

手机站
千锋教育

千锋学习站 | 随时随地免费学

千锋教育

扫一扫进入千锋手机站

领取全套视频
千锋教育

关注千锋学习站小程序
随时随地免费学习课程

当前位置:首页  >  技术干货  > SQL优化与慢查询

SQL优化与慢查询

来源:千锋教育
发布人:yyy
时间: 2023-06-28 14:20:00 1687933200

  一. 慢查询日志

  SQL是我们和数据库交流最重要的部分,所以我们在调优的时候,需要花费的大量时间就在SQL调优上面。

  慢查询日志按照健哥的经验来说就是发现系统中查询慢的SQL语句的有效手段之一。常见的分析手段有慢查询日志,EXPLAIN 分析查询,通过定位分析性能的瓶颈,才能更好的优化数据库系统的性能。

  开启慢查询日志

  在配置文件my.cnf或my.ini中在[mysqld]一行下面加入两个配置参数:

log-slow-queries=/data/mysqldata/slow-query.log
long_query_time=3

   log-slow-queries参数为慢查询日志存放的位置,一般这个目录要有mysql的运行帐号的可写权限,一般都将这个目录设置为mysql的数据存放目录;

  long_query_time=5中的5表示查询超过五秒才记录;

  还可以在my.cnf或者my.ini中添加log-queries-not-using-indexes参数,表示记录下没有使用索引的查询。

  2. 慢查询分析

  我们可以通过打开log文件查看得知哪些SQL执行效率低下 ,从日志中,可以发现查询时间超过5 秒的SQL,而小于5秒的没有出现在此日志中。

  如果慢查询日志中记录内容很多,可以使用mysqldumpslow工具(MySQL客户端安装自带)来对慢查询日志进行分类汇总。mysqldumpslow对日志文件进行了分类汇总,显示汇总后摘要结果。

  进入log的存放目录,运行:

[root@mysql_data]# mysqldumpslow slow-query.log
Reading mysql slow query log fromslow-query.log
Count: 2 Time=11.00s (22s) Lock=0.00s (0s)Rows=1.0 (2), root[root]@mysql
select count(N) from t_user;

   mysqldumpslow命令:

/path/mysqldumpslow -s  c -t 显示SQL条数  日志保存位置

   这会输出记录次数最多的10条SQL语句,其中:

  -s:是表示按照何种方式排序,c、t、l、r分别是按照记录次数、时间、查询时间、返回的记录数来排序,ac、at、al、ar:表示相应的倒叙。

  -t:是top n的意思,即为返回前面多少条的数据。

  -g:后边可以写一个正则匹配模式,大小写不敏感的。

  健哥来给各位小伙伴举个栗子:

/path/mysqldumpslow -s r -t 10  /database/mysql/slow-log

   得到返回记录集最多的10个查询。

  使用mysqldumpslow命令可以非常明确的得到各种我们需要的查询语句,对MySQL查询语句的监控、分析、优化是MySQL优化非常重要的一步。开启慢查询日志后,由于日志记录操作,在一定程度上会占用CPU资源影响mysql的性能,但是可以阶段性开启来定位性能瓶颈。

tags: SQL优化
声明:本站稿件版权均属千锋教育所有,未经许可不得擅自转载。
10年以上业内强师集结,手把手带你蜕变精英
请您保持通讯畅通,专属学习老师24小时内将与您1V1沟通
免费领取
今日已有369人领取成功
刘同学 138****2860 刚刚成功领取
王同学 131****2015 刚刚成功领取
张同学 133****4652 刚刚成功领取
李同学 135****8607 刚刚成功领取
杨同学 132****5667 刚刚成功领取
岳同学 134****6652 刚刚成功领取
梁同学 157****2950 刚刚成功领取
刘同学 189****1015 刚刚成功领取
张同学 155****4678 刚刚成功领取
邹同学 139****2907 刚刚成功领取
董同学 138****2867 刚刚成功领取
周同学 136****3602 刚刚成功领取
相关推荐HOT