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优化主要是从这几点来实现的:

相关推荐
Frank_refuel7 分钟前
终端环境下:Ubuntu 22.04.1 安装 MySQL 数据库
数据库·mysql·ubuntu
虹科网络安全1 小时前
艾体宝产品|深度解读 Redis 8.4 新增功能:原子化 Slot 迁移(下)
数据库·redis·bootstrap
有味道的男人2 小时前
对接亚马逊平台接口,商品全量信息一键抓取
数据库
Web极客码3 小时前
2026年Linux VPS安全加固清单:SSH、防火墙与审计就绪配置
运维·服务器·数据库
逻辑驱动的ken4 小时前
Java高频面试考点18
java·开发语言·数据库·算法·面试·职场和发展·哈希算法
qq_392690664 小时前
Redis怎样应对Redis集群整体宕机带来的雪崩
jvm·数据库·python
快乐非自愿5 小时前
Redis--SDS字符串与集合的底层实现原理
数据库·redis·缓存
这儿有一堆花5 小时前
住宅代理(Residential Proxy)技术指南
开发语言·数据库·php
茉莉玫瑰花茶6 小时前
LangChain 核心组件 [ 2 ]
java·数据库·langchain
存在的五月雨6 小时前
Mysql 索引的一些
数据库·mysql