美文网首页Java
SQL优化之慢查询

SQL优化之慢查询

作者: 西敏寺钟声 | 来源:发表于2020-07-24 18:20 被阅读0次

什么是慢查询

慢查询,顾名思义,就是查询慢的sql语句,是指mysql记录所有执行超过long_query_time参数设定的时间阈值的SQL语句的日志。该日志能为SQL语句的优化带来很好的帮助。默认情况下,慢查询日志是关闭的,要使用慢查询日志功能,首先要开启慢查询日志功能。

慢查询配置

慢查询基本配置

  • slow_query_log 启动停止技术慢查询日志
  • slow_query_log_file 指定慢查询日志得存储路径及文件(默认和数据文件放一起)
  • long_query_time 指定记录慢查询日志SQL执行时间得伐值(单位:秒,默认10秒)
  • log_queries_not_using_indexes 是否记录未使用索引的SQL
  • log_output 日志存放的地方【TABLE】【FILE】【FILE,TABLE】

配置了慢查询后,它会记录符合条件的SQL,包括:

  • 查询语句
  • 数据修改语句
  • 已经回滚的SQL

通过下面命令查看下上面的配置:

  • show VARIABLES like '%slow_query_log%'

  • show VARIABLES like '%slow_query_log_file%'

  • show VARIABLES like '%long_query_time%'

  • show VARIABLES like '%log_queries_not_using_indexes%'

  • show VARIABLES like 'log_output'

  • set global long_query_time=0; -- 默认10秒,这里为了演示方便设置为0

  • set GLOBAL slow_query_log = 1; -- 开启慢查询日志

  • set global log_output='FILE' -- 项目开发中日志只能记录在日志文件中,不能记表中

慢查询日志文件分析

设置完成后,通过 show VARIABLES like 'datadir'来查看数据文件存放的位置。日志文件中的内容格式如下:

# User@Host: [root] @ localhost [127.0.0.1]
# Query_time: 0.000997  
# Lock_time: 0.000000 
# Rows_sent: 5  
# Rows_examined: 5
SET timestamp=1539153057;
SELECT * FROM `t_users` LIMIT 0, 1000;
  • 第一行:用户名 、用户的IP信息、线程ID号
  • 第二行:执行花费的时间【单位:毫秒】
  • 第三行:执行获得锁的时间
  • 第四行:获得的结果行数
  • 第五行:扫描的数据行数
  • 第六行:这SQL执行的具体时间
  • 第七行:具体的SQL语句

慢查询分析工具

Mysqldumpslow

linux系统在mysql的bin目录下执行

./mysqldumpslow -s r -t 5 /usr/local/mysql/data/70KG-224-slow.log


可以看出查询总时间均为0S,是因为语句查询时间太短,实际上是按时间倒序来排的。

参数说明:

mysqldumpslow -s r -t 10 slow-mysql.log
-s order (c,t,l,r,at,al,ar) 
         c:总次数
         t:总时间
         l:锁的时间
         r:总数据行
         at(每次执行sql耗费的时间),al(每次执行sql加锁用的时间),ar(每次获取数据行数所用时间)【例如:at = 总时间/总次数】其中a表示average平均
  -t  top   指定取前面几天作为结果输出

pt_query_digest

这个工具安装起来比较复杂,非专业sql人员感觉没必要玩~

相关文章

  • SQL优化之慢查询

    什么是慢查询 慢查询,顾名思义,就是查询慢的sql语句,是指mysql记录所有执行超过long_query_tim...

  • MySQL性能优化(慢查询)

    1 MySQL性能优化之慢查询 1.1 性能优化的思路 首先需要使用慢查询功能,去获取所有查询时间比较长的SQL语...

  • Java面试题:数据库优化策略有哪些?

    1、Sql优化主要优化的还是查询, 优化查询的话, 索引优化是最有效的方案。 首先要根据需求写出结构良好的SQL,...

  • SQL优化

    SQL优化 在sql查询中为了提高查询效率,我们常常会采取一些措施对查询语句进行sql优化,下面总结的一些方法,有...

  • sql优化之慢sql耗时排查

    sql 语句性能分析 1、看 sql 语句执行时间 2、看 sql 的执行计划 3、查看 sql 的执行中各个环节...

  • 11-mysqlSQL分析

    六星教育 - java-mysql优化1909 SQL优化 所谓SQL优化:基于MySQL的优化器查询规则来优化S...

  • 不可置信!SQL 优化终于干掉了“distinct”

    sql 优化之多表联合查询干掉 “distinct” 去重关键字 所以需要把多表的子查询的 sql 结构进行优化。...

  • mysql 问题整理

    SQL 优化 范式 在sql查询中为了提高查询效率,我们常常会采取一些措施对查询语句进行sql优化,下面总结的一些...

  • MySQL | 使用 limit 优化查询和防止SQL被优化

    使用 limit 优化查询和防止SQL被优化 Table of Contents 查询优化 1.1 最大值和最小值...

  • 数据库索引相关问题

    如何定位并优化慢查询Sql 根据慢日志定位慢查询sql 使用explain等工具分析sql 修改sql或者尽量让s...

网友评论

    本文标题:SQL优化之慢查询

    本文链接:https://www.haomeiwen.com/subject/lartlktx.html