MySQL

一、如何定位慢查询

1、使用Prometheus(普罗米修斯)、集团自研的SQL统计的工具等去查看慢SQL

2、查看应用日志,我们的应用执行SQL都会打印执行时间,可以帮助我们定位到哪些SQL太慢

二、一个SQL执行很慢,如何分析

可以使用explain或者desc命令获取MySQL如何执行select语句的信息

语法:

explain select 字段列表 from 表名 where 条件;

如上图:

使用执行计划explain后,MySQL会响应这条查询语句的信息了,其中比较重要的有:

  • possible_key:当前SQL可能用到的索引;我之前那家公司任职期间就是没看到可能的索引,结果真的索引走偏,后来强行绑定执行索引才回复正常
  • key:表示这条SQL实际上走的索引
  • key_len:表示所使用的索引的长度,可以用来判断使用了联合索引后,走了其中哪几个字段的索引
  • extra:表示MySQL给你的额外的优化建议,这里是null;如果有的话会有:"Using where"、"Using Index"等建议
  • type:这条SQL的连接的类型,性能由好到差分别为:null、system、const、eq_ref、ref、range、index、all

type中:system:表示查询MySQL自带的表,性能极好,但是与一般的开发无关

const:表示使用主键查询

eq_ref:表示使用主键查询或者唯一索引查询,只返回一条数据

ref:根据其他的普通索引查询

range:走的是索引,但是是范围查询

index:索引树查询

all:全表扫描查询

大表select的最低要求,至少也要走range级别及以上的级别,不然性能太低了

相关推荐
爱吃土豆的马铃薯ㅤㅤㅤㅤㅤㅤㅤㅤㅤ3 分钟前
获取容器mysql管理员密码命令
数据库·mysql
JAVA学习通6 分钟前
《大营销平台系统设计实现》 - 营销服务 第5节:抽奖前置规则过滤
java·数据库·github
斯特凡今天也很帅8 分钟前
新建数据源报错No bean named ‘SqlSessionFactorykf‘ available
java·数据库·spring boot·mybatis
Trouvaille ~10 分钟前
【Redis篇】为什么需要 Redis:从单机到分布式的架构演进之路
数据库·redis·分布式·缓存·中间件·架构·后端开发
ID_1800790547313 分钟前
Taobao & 1688 Product API Technical Overview and JSON Response Reference
数据库
June`19 分钟前
多线程redis项目之aof
数据库·redis·缓存
Peter-OK29 分钟前
Redis从3.x到8.4的核心新特性深度解析与实战学习指南
数据库·redis·缓存
文青小兵33 分钟前
云计算Linux——数据库MySQL读写分离、数据库备份、恢复(十八)
linux·运维·服务器·数据库·mysql·云计算
成为你的宁宁39 分钟前
【Prometheus监控Nginx/Mysql/Redis/Docker/Rabbitmq】
mysql·nginx·prometheus
@我漫长的孤独流浪43 分钟前
SQL触发器实战:银行系统数据完整性控制
数据库·oracle