SQL优化
创始人
2024-02-08 09:50:09
0

文章目录

  • 提升group by的效率
  • 分页查询优化
    • 覆盖索引+子查询
    • 起始位置重定义
  • 检查 where,order by,group by后面的列
  • 尽量使用 varchar 代替 char。(SQL 性能优化)
  • 如果修改 / 更新数据过多,考虑批量进行

提升group by的效率

select user_id,user_name from order
group by user_id
having user_id <= 200;

分组是一个相对耗时的操作,为什么我们不先缩小数据的范围之后,再分组呢?

select user_id,user_name from order
where user_id <= 200
group by user_id

分页查询优化

覆盖索引+子查询

[SQL]
SELECT a.empno,a.empname,a.job,a.sal,b.depno,b.depname
from emp a left join dep b on a.depno = b.depno
where a.id >= (select id from emp order by id limit 100,1)
order by a.id limit 25;
受影响的行: 0
时间: 0.106s
[SQL]
SELECT a.empno,a.empname,a.job,a.sal,b.depno,b.depname
from emp a left join dep b on a.depno = b.depno
where a.id >= (select id from emp order by id limit 4800000,1)
order by a.id limit 25;
受影响的行: 0
时间: 1.541s

起始位置重定义

[SQL]
SELECT a.id,a.empno,a.empname,a.job,a.sal,b.depno,b.depname
from emp a left join dep b on a.depno = b.depno
where a.id > 100 order by a.id limit 25;
受影响的行: 0
时间: 0.001s
[SQL]
SELECT a.id,a.empno,a.empname,a.job,a.sal,b.depno,b.depname
from emp a left join dep b on a.depno = b.depno
where a.id > 4800000  # 从4800000 开始
order by a.id limit 25;
受影响的行: 0
时间: 0.000s

检查 where,order by,group by后面的列

多表关联的列是否已加索引,优先考虑组合索引

# 添加索引
alter table user add index idx_address_age (address,age);

在这里插入图片描述

尽量使用 varchar 代替 char。(SQL 性能优化)

「反例:」

`deptName` char(100) DEFAULT NULL COMMENT '部门名称'

「正例:」

`deptName` varchar(100) DEFAULT NULL COMMENT '部门名称'

理由:

  • 因为首先变长字段存储空间小,可以节省存储空间
  • 其次对于查询来说,在一个相对较小的字段内搜索,效率更高

如果修改 / 更新数据过多,考虑批量进行

反例:

delete from account limit 100000;

正例:

for each(200 次)
{
delete from account limit 500;
}

理由:

  • 大批量操作会会造成主从延迟
  • 大批量操作会产生大事务,阻塞
  • 大批量操作,数据量过大,会把 cpu 打满

相关内容

热门资讯

喜欢穿一身黑的男生性格(喜欢穿... 今天百科达人给各位分享喜欢穿一身黑的男生性格的知识,其中也会对喜欢穿一身黑衣服的男人人好相处吗进行解...
发春是什么意思(思春和发春是什... 本篇文章极速百科给大家谈谈发春是什么意思,以及思春和发春是什么意思对应的知识点,希望对各位有所帮助,...
网络用语zl是什么意思(zl是... 今天给各位分享网络用语zl是什么意思的知识,其中也会对zl是啥意思是什么网络用语进行解释,如果能碰巧...
为什么酷狗音乐自己唱的歌不能下... 本篇文章极速百科小编给大家谈谈为什么酷狗音乐自己唱的歌不能下载到本地?,以及为什么酷狗下载的歌曲不是...
华为下载未安装的文件去哪找(华... 今天百科达人给各位分享华为下载未安装的文件去哪找的知识,其中也会对华为下载未安装的文件去哪找到进行解...
家里可以做假山养金鱼吗(假山能... 今天百科达人给各位分享家里可以做假山养金鱼吗的知识,其中也会对假山能放鱼缸里吗进行解释,如果能碰巧解...
四分五裂是什么生肖什么动物(四... 本篇文章极速百科小编给大家谈谈四分五裂是什么生肖什么动物,以及四分五裂打一生肖是什么对应的知识点,希...
怎么往应用助手里添加应用(应用... 今天百科达人给各位分享怎么往应用助手里添加应用的知识,其中也会对应用助手怎么添加微信进行解释,如果能...
客厅放八骏马摆件可以吗(家里摆... 今天给各位分享客厅放八骏马摆件可以吗的知识,其中也会对家里摆八骏马摆件好吗进行解释,如果能碰巧解决你...
美团联名卡审核成功待激活(美团... 今天百科达人给各位分享美团联名卡审核成功待激活的知识,其中也会对美团联名卡审核未通过进行解释,如果能...