当前位置: 首页 > news >正文

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级别及以上的级别,不然性能太低了

相关文章:

  • CCF-CSP第19次认证第一题——线性分类器【NA】
  • Deep seek学习日记1
  • 人工智能 - 主动视觉可能就是你所需要的:在双臂机器人操作中探索主动视觉
  • 学习笔记之debian的thonny开发(尚未验证)--从stm32裸机到linux嵌入式系统
  • windows11+ubuntu20.04双系统下卸载ubuntu并重新安装
  • 人工智能 - 机器学习、深度学习、强化学习是人工智能领域的理论基础和方法论
  • Docker 修改配置后无法启动问题
  • Python笔记
  • 红队视角出发的k8s敏感信息收集——Kubernetes API 扩展与未授权访问
  • 腿足机器人之七- 逆运动学
  • PostgreSQL有undo表空间吗?
  • 【Scrapy】Scrapy教程2——工作原理
  • Tetragon:一款基于eBPF的运行时环境安全监控工具
  • 数据库开发常识(10.6)——SQL性能判断标准及索引误区(1)
  • Python学习心得正则表达式及re模块的使用
  • Endnote使用笔记——持续更新
  • 使用新版本golang项目中goyacc依赖问题的处理
  • 后端开发:高效数据库查询优化实战指南
  • JavaScript系列(74)--反射API详解
  • C语言基础15:冒泡排序
  • 市场监管总局出手整治涉企乱收费,聚焦政府部门及下属单位等领域
  • 铺就长三角南北“交通动脉”,乍嘉苏改高速扩建项目首桩入位
  • “75后”袁达已任国家发改委秘书长
  • 卸任兰大校长后,严纯华院士重返北大作报告
  • “85后”潘欢欢已任河南中豫融资担保有限公司总经理
  • 新经济与法|如何治理网购刷单与控评?数据合规管理是关键