【MySQL】慢SQL优化

本文涉及的产品
云数据库 RDS MySQL Serverless,0.5-2RCU 50GB
简介: 慢SQL优化老生常谈了,今天聊一下优化时遇到的几个坑点。

MySQL系列文章

分析SQL

搜集sql

image.png

  • 按平均耗时倒序排序,取前10个进行优化

查看执行计划

  • 通过explain查看sql执行计划


关键字

解释

table

表名

type

连接的数据类型,由好到差const、eq_ref、ref、range、index、all

const表最多有一个匹配行,它将在查询开始时被读取。因为仅有一行,在这行的列值可被优化器剩余部分认为是常数。const表很快,因为它们只读取一次

eq_ref对于每个来自于前面的表的行组合,从该表中读取一行。这可能是最好的联接类型,除了const类型。

ref:对于每个来自于前面的表的行组合,所有有匹配索引值的行将从这张表中读取。

range:只检索给定范围的行,使用一个索引来选择行。

index:该联接类型与ALL相同,除了只有索引树被扫描。这通常比ALL快,因为索引文件通常比数据文件小

all:对于每个来自于先前的表的行组合,进行完整的表扫描。

rows

估算扫描行数

extra

using index condition:搜索条件中虽然出现了索引列,但是有部分条件无法使用索引,会根据能用索引的条件先搜索一遍再匹配无法使用索引的条件。

key

适用的索引

image.png

  • 主要注意几个地方
  • key:执行器选择的索引
  • rows:估算的扫描数据行数


缺少索引

看完执行计划之后判断是否缺少索引就很明朗了,直接看explain语句返回结果的key,如果为空则说明没有走索引。


创建索引要本着以结合where条件区分度最高的原则创建,考虑以下几个方面

联合索引最左匹配原则

  • 最左前缀匹配:mysql会一直向右匹配直到遇到范围查询
  • 联合索引结合索引结构推断,索引会在范围查询断掉
  • 最左优先,在检索数据时从联合索引的最左边开始匹配
  • 遇到范围查询(>、<、between、like)比较就会停止
  • 举例:
  • 创建一个 index_magor_class(magor,class) 的联合索引,那么它的索引树就是下图的样子
  • 我们查询的where 条件如果只传入了班级,是走不到联合索引的,但是如果只传了学院编号,是可能会走到联合索引的。(为什么说可能,MYSQL的执行计划和查询的实际执行过程并不完全吻合,比如你数据库数据量很少,可能直接全量遍历速度更快,就不走索引了)

索引覆盖

  • 结合业务场景适当考虑索引覆盖
  • 普通的索引查询步骤为,现根据索引定位到主键,再根据主键去查找数据行(回表操作)
  • 指查询列在索引列中,不需要回表操作


索引失效

  • 时间类型data_format会导致时间字段索引失效
  • 可以用date(ctime) < str_to_date('2019-12-30', '%Y-%m-%d')
  • 对索引字段使用计算操作或函数失效,类似&运算等
  • 使用like %key%使索引失效,大数据量全文检索尽量使用es
  • or关键字前后没有同时使用索引
  • 联合索引最左匹配原则顺序不符合规则
  • 索引字段使用is null 或 is not null
  • join语句字段编码不一致导致引擎走错索引
  • case when不走索引


业务分析

深度分页

  • 尽量在产品层上规避掉此类需求,比如操作日志,除了出大问题谁会看自己几月前甚至几年前的操作。
  • 规避不了的话就要考虑深度分页方案
  • limit n, m; n代表偏移量通常在业务系统需要page_no * page_size如果偏移量很大如何优化
  • 参考es的深度分页策略,滚动分页。利用id连续返回上次查询的最大记录(偏移量),基于上一次查询偏移量作为where条件
  • 业务中限制页数
  • 先通过索引列拿到主键,通过主键回表查详情
select a.*from emp a,(select id from emp limit1000000,10) b where a.id= b.id


是否需要select *

  • 查询字段会占用网络带宽,也会拖慢sql执行,所以尽量避免select *情况,按需查询





相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
17天前
|
关系型数据库 MySQL 索引
mysql 分析5语句的优化--索引添加删除
mysql 分析5语句的优化--索引添加删除
13 0
|
17天前
|
SQL 缓存 关系型数据库
mysql性能优化-慢查询分析、优化索引和配置
mysql性能优化-慢查询分析、优化索引和配置
83 1
|
1天前
|
SQL 关系型数据库 MySQL
不允许你不知道的 MySQL 优化实战(一)
不允许你不知道的 MySQL 优化实战(一)
|
2天前
|
存储 缓存 关系型数据库
掌握MySQL数据库这些优化技巧,事半功倍!
掌握MySQL数据库这些优化技巧,事半功倍!
|
2天前
|
缓存 关系型数据库 MySQL
MySQL数据库优化技巧:提升性能的关键策略
索引是提高查询效率的关键。根据查询频率和条件,创建合适的索引能够加快查询速度。但要注意,过多的索引可能会增加写操作的开销,因此需要权衡。
|
3天前
|
SQL Oracle 关系型数据库
下次老板问你MySQL如何优化时,你可以这样说,老板默默给你加工资
现在进入国企或者事业单位做技术的网友越来越多了,随着去O的力度越来越大,很多国企单位都开始从Oracle向MySQL转移,相对于Oracle而言,MySQL最大的问题就是性能,所以,这个时候,在公司如果能够处理好MySQL的性能瓶颈,那么你也就很容易从人群中脱颖而出,受到老板的青睐。
22 1
|
4天前
|
SQL 分布式计算 资源调度
一文解析 ODPS SQL 任务优化方法原理
本文重点尝试从ODPS SQL的逻辑执行计划和Logview中的执行计划出发,分析日常数据研发过程中各种优化方法背后的原理,覆盖了部分调优方法的分析,从知道怎么优化,到为什么这样优化,以及还能怎样优化。
|
11天前
|
SQL 关系型数据库 数据库
【后端面经】【数据库与MySQL】SQL优化:如何发现SQL中的问题?
【4月更文挑战第12天】数据库优化涉及硬件升级、操作系统调整、服务器/引擎优化和SQL优化。SQL优化目标是减少磁盘IO和内存/CPU消耗。`EXPLAIN`命令用于检查SQL执行计划,关注`type`、`possible_keys`、`key`、`rows`和`filtered`字段。设计索引时考虑外键、频繁出现在`where`、`order by`和关联查询中的列,以及区分度高的列。大数据表改结构需谨慎,可能需要停机、低峰期变更或新建表。面试中应准备SQL优化案例,如覆盖索引、优化`order by`、`count`和索引提示。优化分页查询时避免大偏移量,可利用上一批的最大ID进行限制。
38 3
|
3天前
|
SQL 存储 关系型数据库
MySQL Cluster集群安装及使用
MySQL Cluster集群安装及使用