SQL 调优需要掌握的知识

SQL 调优本质上就一句话:

减少 MySQL 扫描的数据量,减少排序、临时表和回表,让数据库用尽可能低的成本拿到结果。

更具体地说:

全表扫描慢,是因为读的数据太多
索引快,是因为 B+ 树可以快速定位范围
复合索引快,是因为它可以同时服务过滤和排序
覆盖索引快,是因为减少了回表
深分页慢,是因为扫描并丢弃了大量数据
函数、前置模糊匹配慢,是因为破坏了索引的有序性

sql执行过程

SELECT id, username
FROM t_user
WHERE create_time < '2025-01-01 12:00:00'
  AND status = 1
ORDER BY age ASC;

当进行sql扫描的时候,SQL会收集需要的字段,并不是把一行数据全都加到暂存区

读取:从 InnoDB 数据页里把记录读出来
暂存:MySQL 为了排序、分组、返回结果临时保存一些字段

InnoDB:把一行记录读出来给 MySQL
MySQL:判断 WHERE
MySQL:只把后面要排序/返回的字段放进临时结构

需要的字段

status
age
create_time
id
username
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值