我们经常会接触到MySQL,也经常会遇到一些MySQL的性能问题。我们可以借助慢查询日志和explain命令初步分析出SQL语句存在的性能问题

通过SHOW FULL PROCESSLIST查看问题

SHOW FULL PROCESSLIST相当于select * from information_schema.processlist可以列出正在运行的连接线程,

processlist

说明:

  • id 连接id,可以使用kill+连接id的方式关闭连接(kill 9339)
  • user显示当前用户
  • host显示连接的客户端IP和端口
  • db显示进程连接的数据库
  • command显示当前连接的当前执行的状态,sleep、query、connect
  • time显示当前状态持续的时间(秒)
  • state显示当前连接的sql语句的执行状态,copying to tmp table、sorting result、sending data等
  • info显示sql语句,如果发现比较耗时的语句可以复制出来使用explain分析。

慢查询日志

慢查询日志是MySQL用于记录响应时间超过设置阈值(long_query_time)的SQL语句,默认情况下未开启慢查询日志,需要手动配置。
下面我们要记住几个常用的属性:

  • slow_query_log:是否开启慢查询(ON为开启,OFF则为关闭)
  • long_query_time:慢查询阀值,表示SQL语句执行时间超过这个值就会记录,默认为10s
  • slow_query_log_file:慢查询日志存储的文件路径
  • log_queries_not_using_indexes: 记录没有使用索引查询语句(ON为开启,OFF为关闭)
  • log_output:日志存储方式(FILE表示将日志写入文件,TABLE表示写入数据库中,默认值为FILE,如果存入数据库中,我们可以通过select * from mysql.slow_log的方式去查询,一般性能要求相对较高的建议存文件)

我们可以通过show variables like ‘%关键字%’的方式查询我们设置的属性值

slow

我们有两种方式设置我们的属性,一种是set global 属性=值的方式(重启失效),另一种是配置文件(重启生效)
命令方式:

set global slow_query_log=1;set global long_query_time=1; set global slow_query_log_file='mysql-slow.log'

配置文件方式:

slow_query_log = 'ON'slow_query_log_file = D:/Tools/mysql-8.0.16/slow.loglong_query_time = 1log-queries-not-using-indexes

pt-qurey-digest分析慢查询语句

percona-toolkit包含了很多实用强大的mysql工具包,pt-qurey-digest只是其中一个用于分析慢查询日志是工具。需要去官网下载,使用方法也很简单:

./pt-query-digest slow2.log >> slow2.txt

即可得出一个分析结果:

# Query 9: 0.00 QPS, 0.00x concurrency, ID 0xF914D8CC2938CE6CAA13F8E57DF04B2F at byte 499246# This item is included in the report because it matches --limit.# Scores: V/M = 0.22# Time range: 2019-07-08T03:56:12 to 2019-07-12T00:46:28# Attribute    pct   total     min     max     avg     95%  stddev  median# ============ === ======= ======= ======= ======= ======= ======= =======# Count          8      69# Exec time      1    147s      1s      3s      2s      3s   685ms      2s# Lock time      0   140ms     2ms    22ms     2ms     3ms     2ms     2ms# Rows sent      0       0       0       0       0       0       0       0# Rows examine   0  23.96M 225.33k 482.77k 355.65k 462.39k  81.66k 345.04k# Query size     2  17.72k     263     263     263     263       0     263# String:# Databases    xxxx# Hosts        xx.xxx.xxx.xxx# Users        root# Query_time distribution#   1us#  10us# 100us#   1ms#  10ms# 100ms#    1s  #################################################################  10s+# Tables#    SHOW TABLE STATUS FROM `xxxx` LIKE 'xxxxx_track_exec_channel'G#    SHOW CREATE TABLE `xxxx`.`xxxxxxxx_exec_channel`G#    SHOW TABLE STATUS FROM `xxx` LIKE 'xxxxx_TRACK_ASSIGN'G#    SHOW CREATE TABLE `xxxx`.`xxxxx_EFFECTIVE_TRACK_ASSIGN`G#    SHOW TABLE STATUS FROM `xxx` LIKE 'xxxx_task_exec'G#    SHOW CREATE TABLE `xxxx`.`xxxxx_task_exec`GUPDATExxxxxx_effective_track_exec_channel a SET EXEC_CHANNEL_CODE=(SELECT GROUP_CONCAT(DISTINCT(channel_id)) FROM xxxxxx_EFFECTIVE_TRACK_ASSIGN WHERE status in (1,2,4) AND id IN (SELECT assgin_id FROM xxxxxx_task_exec WHERE task_id=a.task_id))G

explain分析SQL语句

上面几点大概的介绍到了几种获取慢查询SQL语句的方式,现在,我们就需要借助explain来分析查找SQL语句慢的原因。explain使用也很简单,直接在SELECT|UPDATE等语句前加上EXPLAIN即可

explain

id

表的执行顺序,复制的sql语句往往会分为很多步,序号越大越先执行,id相同执行顺序从上往下

select_type

数据读取操作的操作类型:

  • SIMPLE(简单SELECT,不使用UNION或子查询等)
  • PRIMARY(子查询中最外层查询,查询中若包含任何复杂的子部分,最外层的select被标记为PRIMARY)
  • UNION(UNION中的第二个或后面的SELECT语句)
  • DEPENDENT UNION(UNION中的第二个或后面的SELECT语句,取决于外面的查询)
  • UNION RESULT(UNION的结果,union语句中第二个select开始后面所有select)
  • SUBQUERY(子查询中的第一个SELECT,结果不依赖于外部查询)
  • DEPENDENT SUBQUERY(子查询中的第一个SELECT,依赖于外部查询)
  • DERIVED(派生表的SELECT, FROM子句的子查询)
  • UNCACHEABLE SUBQUERY(一个子查询的结果不能被缓存,必须重新评估外链接的第一行)

table

数据来源于那张表,关联等复杂查询时会用临时虚拟表

type

检索数据的方式

  • system:表只有一行记录
  • const:通过索引查找并且一次性找到
  • eq_ref:唯一性索引扫描
  • ref:非唯一行索引扫描
  • range:按范围查找
  • index:遍历索引树
  • all:全表扫描

possible_keys

显示可能使用的索引

Key

实际使用的索引

key_len

索引的长度,一般来说,长度越短越好

ref

列与索引的比较,表示上述表的连接匹配条件,即哪些列或常量被用于查找索引列上的值

rows

估算查找的结果记录条数

Extra

SQL查询的详细信息

  • Using where:表示使用where条件过滤
  • Using temporary:使用了临时表暂存结果
  • Using filesort:说明mysql对数据使用一个外部索引排序。未按照表内的索引顺序进行读取。
  • Using index:表示select语句中使用了覆盖索引,直接从索引中取值
  • Using join buffer:使用了连接缓存
  • Using index condition:表示查询的列有非索引的列

[参考]
MySQL Explain详解

mysql 关联查询慢_mysql慢查询语句分析总结相关推荐

  1. mysql去重复查询 性能_MySQL中distinct语句去查询重复记录及相关的性能讨论_MySQL...

    在 MySQL 查询中,可能会包含重复值.这并不成问题,不过,有时您也许希望仅仅列出不同(distinct)的值. 关键词 DISTINCT 用于返回唯一不同的值,就是去重啦.用法也很简单: SELE ...

  2. mysql去重复查询 性能_MySQL中distinct语句去查询重复记录及相关的性能讨论

    在 MySQL 查询中,可能会包含重复值.这并不成问题,不过,有时您也许希望仅仅列出不同(distinct)的值. 关键词 DISTINCT 用于返回唯一不同的值,就是去重啦.用法也很简单: SELE ...

  3. mysql 高级查询词_Mysql高级查询语句

    Exists子查询 Exists的特点 1.在执行create或drop语句前,可以使用exists语句来判断数据库对象是否存在,返回值是true或false drop table if exists ...

  4. mysql 慢日志 作用_MySQL慢查询日志的作用和开启

    前言 MySQL的慢查询日志是MySQL提供的一种日志记录,它用来记录在MySQL中响应时间超过阀值的语句,具体指运行时间超过long_query_time值的SQL,则会被记录到慢查询日志中.lon ...

  5. mysql 查询重写_mysql 学习 - 查询重写规则

    条件化简 我们编写的查询语句的搜索条件本质上是一个表达式,这些表达式可能比较繁杂,或者不能高效的执行,MySQL的查询优化器会为我们简化这些表达式. 移除不必要的括号 有时候表达式里有许多无用的括号, ...

  6. mysql慢查询单位_MySQL慢查询

    MySQL的慢查询,全名是慢查询日志,是MySQL提供的一种日志记录,用来记录在MySQL中响应时间超过阀值的语句.具体环境中,运行时间超过long_query_time值的SQL语句,则会被记录到慢 ...

  7. mysql or中有空查询慢_MySQL 慢查询日志

    1.定义 2.相关参数 2.开启 3.原因 4.慢查询日志工具mysqldumpslow 1.定义 作用:用来记录在MySQL中响应时间超过阀值的语句. 2.相关参数 mysql> show v ...

  8. mysql两个表查询修改_MySQL:查询、修改(二)

    干货: 使用SELECT查询的基本语句SELECT * FROM 可以查询一个表的所有行和所有列的数据.SELECT查询的结果是一个二维表. 使用SELECT *表示查询表的所有列,使用SELECT ...

  9. c mysql清理日志文件_MySQL 一般查询日志或者慢查询日志历史数据的清理

    general log&slow query log 对于MySQL的一般查询日志和慢查询日志,开启比较简单,其中公用的一个参数是log_output,log_output控制着慢查询和一般查 ...

最新文章

  1. SAP WM初阶LQ02报错 - Movement Type 901 for manual transfer orders does not exist -
  2. 计算机教资笔试答题,教资笔试5大题型的解答技巧,你get到了嘛?
  3. 幼儿园带括号算式口诀_整理41组“数学顺口溜”+大九九乘法口诀表!给孩子们收藏...
  4. python 实现队列功能 queue insert() pop()
  5. 感知机(python实现)
  6. Cypress 的 before 和 beforeEach 钩子函数的使用方式
  7. Spring security (一)架构框架-Component、Service、Filter分析
  8. python和c先学哪个-初学者python和c语言先学哪个好呢?
  9. hdu4318 最短路变形
  10. mysql关键字 distinct去重
  11. matlab在mac中好用吗,Matlab Mac版上手
  12. MAC chrome 谷歌浏览器全屏显示——隐藏菜单栏
  13. Oracle树形结构拖拽之插队重新排序
  14. (上)苹果有开源,但又怎样呢?
  15. Envi处理MODIS流程
  16. Qt - 添加Logo
  17. vos3000客户在设置服务器防火墙时需要打开哪些 VOS 应用端口
  18. Java FlowLayout(流式布局)布局管理器
  19. python在概率论与数理统计中的作用
  20. 设计模式之备忘录模式详解

热门文章

  1. “四方定理”--蓝桥杯
  2. android 获取webView高度,设置webView高度
  3. 变频器服务器电路板维修,变频器电路板维修技巧
  4. idea2020.03打开项目注释变为显示模式,大于等于等符号也变为中文符号
  5. 请领导批阅文件怎么说_领导说“谢谢”,该怎么回?低情商才说不客气,高情商的都这样说!...
  6. activiti5.22 springboot 流程引擎 实战全过程
  7. vue登录如何存储cookie_vue保持用户登录状态(各种token存储方式)
  8. 第七章 比高斯更快的计算
  9. linux安装数据库依赖包,Linux下安装DB2的包依赖
  10. 【C语言进阶深度学习记录】七 C语言中的循环语句