sql慢查询解决方案
创始人
2025-05-30 19:54:25
0

一、慢查询产生原因

大体有以下三种可能:

1、索引没有设计好;

2、SQL 语句没写好;

3、MySQL 选错了索引。

二、慢查询解决方案

1、针对索引没有设计好的解决方案:给表重新加索引重新加索引

2、针对SQL 语句没写好的解决方案:重写sql语句

【下一版本修复】:检查业务代码中的sql,是否使用了条件字段函数操作、是否有隐式转化【

①检查是否在搜索条件中使用了条件字段函数操作(例如month活动id+1=1000等),导致优化器放弃走树搜索功能,走全索引扫描

② 比如id值为string,查询语句用了int(对索引字段做函数操作,可能会破坏索引值的有序性,因此优化器就决定放弃走树搜索功能。)

③ 由于字符集不同(utf8mb4),导致表连接查询的时候用不上关联字段索引,需要把转化放在条件=的后面,就可以使用索引

a、两张表的字符集改成统一

b、sql改写,需要把转化放在条件=的后面来使用索引】

【线上紧急修复】:数据库执行层:使用query_rewrite功能让执行的sql重写成可以使用索引的语句

3、针对MySQL 选错了索引的解决方案:

【线上紧急修复】:就是给这个语句加上 force index,使用查询重写功能,给原来的语句加上 force index,也可以解决这个问题。

【不紧急】:

① 使用force index:分析不同索引的查询条数,比如用索引a需要查询5000条、索引b需要查询1000条,此时明显选索引b查询效率更高,但是mysql优化器选择了索引a(因为优化器还会考虑回表、排序等综合因素导致选错),我们需要 force index与原sql做对比,根据结果考虑是否需要使用force index

② 改写语句:例如“select * from t where (a between 1 and 1000) and (b between 50000 and 100000) order by b limit 1;”语句中将”order by b limit 1” 改成 “order by b,a limit 1” ,要求按照 b,a 排序,就意味着使用这两个索引都需要排序。因此,扫描行数成了影响决策的主要条件

③在有些场景下,我们可以新建一个更合适的索引,来提供给优化器做选择,或删掉误用的索引。

上一篇:牛客--反转链表

下一篇:docker镜像操作

相关内容

热门资讯

【MySQL】锁 锁 文章目录锁全局锁表级锁表锁元数据锁(MDL)意向锁AUTO-INC锁...
【内网安全】 隧道搭建穿透上线... 文章目录内网穿透-Ngrok-入门-上线1、服务端配置:2、客户端连接服务端ÿ...
GCN的几种模型复现笔记 引言 本篇笔记紧接上文,主要是上一篇看写了快2w字,再去接入代码感觉有点...
数据分页展示逻辑 import java.util.Arrays;import java.util.List;impo...
Redis为什么选择单线程?R... 目录专栏导读一、Redis版本迭代二、Redis4.0之前为什么一直采用单线程?三、R...
【已解决】ERROR: Cou... 正确指令: pip install pyyaml
关于测试,我发现了哪些新大陆 关于测试 平常也只是听说过一些关于测试的术语,但并没有使用过测试工具。偶然看到编程老师...
Lock 接口解读 前置知识点Synchronized synchronized 是 Java 中的关键字,...
Win7 专业版安装中文包、汉... 参考资料:http://www.metsky.com/archives/350.htm...
3 ROS1通讯编程提高(1) 3 ROS1通讯编程提高3.1 使用VS Code编译ROS13.1.1 VS Code的安装和配置...
大模型未来趋势 大模型是人工智能领域的重要发展趋势之一,未来有着广阔的应用前景和发展空间。以下是大模型未来的趋势和展...
python实战应用讲解-【n... 目录 如何在Python中计算残余的平方和 方法1:使用其Base公式 方法2:使用statsmod...
学习u-boot 需要了解的m... 一、常用函数 1. origin 函数 origin 函数的返回值就是变量来源。使用格式如下...
常用python爬虫库介绍与简... 通用 urllib -网络库(stdlib)。 requests -网络库。 grab – 网络库&...
药品批准文号查询|药融云-中国... 药品批文是国家食品药品监督管理局(NMPA)对药品的审评和批准的证明文件...
【2023-03-22】SRS... 【2023-03-22】SRS推流搭配FFmpeg实现目标检测 说明: 外侧测试使用SRS播放器测...
有限元三角形单元的等效节点力 文章目录前言一、重新复习一下有限元三角形单元的理论1、三角形单元的形函数(Nÿ...
初级算法-哈希表 主要记录算法和数据结构学习笔记,新的一年更上一层楼! 初级算法-哈希表...
进程间通信【Linux】 1. 进程间通信 1.1 什么是进程间通信 在 Linux 系统中,进程间通信...
【Docker】P3 Dock... Docker数据卷、宿主机与挂载数据卷的概念及作用挂载宿主机配置数据卷挂载操作示例一个容器挂载多个目...