MySQL优化系列

首先需要明确,什么时候mysql需要进行优化,哪些地方需要优化,如何进行优化

对于mysql的优化,分为下面几个部分:

  1. 定位慢查询
  2. 分析SQL执行计划
  3. 索引
  4. SQL优化经验

1.如何定位慢查询

慢查询出现的情况如下:

定位慢查询的方式:

1.使用开源工具

2.使用mysql自带慢日志

开启慢日志查询后,需要重新启动Mysql服务器进行测试,可以查看慢日志文件中记录的信息

在定位了慢查询以后,要进行分析优化

2.分析sql语句

可以采用EXPLAIN或者DESC命令获取Mysql如何执行SELECT语句的信息

这里面有很多字段,我们需要进行逐个分析

重点就是key_len、key、type、extra这几个字段

3.索引优化

如果我们的查询发生了索引未命中或者索引失效以及回表查询等情况时,查询就会比较慢,此时我们就需要对索引进行优化

1.对于回表查询,如果数据量比较大可以使用覆盖索引或者建立联合索引

2.对于索引失效,我们可以修改使用方式

3.对于未命中索引,我们可以新建索引

4.Mysql超大分页如何解决

索引的创建原则:

5.SQL优化经验

SQL优化主要是从这几点来实现的:

相关推荐
小陈phd3 分钟前
Text2SQL智能体学习笔记(二)——NL2SQL落地的隐形基石:元数据库
数据库·笔记·学习
霸道流氓气质4 分钟前
阿里云 OSS 从零到实战:概念、配置与 Spring Boot 集成指南
数据库·spring boot·阿里云
茉莉玫瑰花茶5 分钟前
综合案例 - AI 智能租房助手 [ 4 ]
数据库·python·ai·langgraph
ULIi096kr7 分钟前
MySQL查看表创建时间、修改时间、最后更新时间(精准排查僵尸表)
数据库·mysql
折哥的程序人生 · 物流技术专研20 分钟前
Tomcat 严重警告:JDBC 驱动未注销 + 工作线程泄漏 —— 原因、影响与彻底修复(生产级终极指南)
java·运维·数据库·mysql·oracle·tomcat
初圣魔门首席弟子25 分钟前
Qt C++ 项目实战:修改共享头文件后的高效增量编译与快速发布流程
数据库
wb0430720126 分钟前
仓库搬家不停业——从阿明的“在线换仓库“,看数据库迁移与 Schema 演进的实战方法论
数据库·adb·架构
lx1885486989630 分钟前
Redis大Key阻塞:单线程CPU100%的致命陷阱
数据库·redis·缓存
IT策士33 分钟前
Redis 从入门到精通:位图、HyperLogLog、GEO
数据库·redis·缓存
拄杖忙学轻声码43 分钟前
mysql脚本查询数据,符合指定条件的排在数据列表最前面,实现方式
mysql