【MySQL-索引调优】11:Group by相关概念

作用 :把结果集按照某些字段分组,每组再进行聚合计算(如 COUNT, SUM, AVG, MAX, MIN

例如:

sql 复制代码
SELECT user_id, COUNT(*) AS order_count
FROM orders
GROUP BY user_id;

1-GROUP BY的两种执行方式

1-1.有索引

利用索引分组,执行流程:

复制代码
扫描索引
→ 同 user_id 的数据天然连续
→ 直接统计

1-2.无索引

临时表分组,执行流程:

复制代码
扫描数据
→ 放入临时表
→ 排序
→ 再聚合

2-最左匹配原则

GROUP BY 想用索引,必须满足,最左匹配原则:

sql 复制代码
GROUP BY 字段 = 索引最左列
# 例如:
# 索引:(user_id,status),SQL:GROUP BY user_id,可以使用索引
# 索引:(user_id,status),SQL:GROUP BY status,不能使用索引
相关推荐
曹牧15 小时前
C#:主线程能够捕获到子线程中的异常
开发语言·数据库·c#
朝阳58115 小时前
MongoDB 副本集从零搭建到生产可用
数据库·mongodb
雨辰AI16 小时前
SpringBoot3 整合达梦 DM9 超详细入门实战|从零搭建可直接上线
数据库·微服务·架构·政务
我是一颗柠檬16 小时前
【MySQL全面教学】MySQL性能优化实战Day13(2026年)
数据库·后端·sql·mysql·性能优化·database
AI人工智能+电脑小能手16 小时前
【大白话说Java面试题 第84题】【Mysql篇】第14题:为什么用 InnoDB 存储引擎的表建议用整型的自增主键?
java·开发语言·数据库·mysql·面试
张彦峰ZYF16 小时前
检索增强生成(RAG)系统的基础:全面深入矢量数据库
数据库·大模型·rag
牧羊狼的狼17 小时前
MySQL 四大索引失效写法 + 业务替代最优解决方案
mysql·索引失效
Elastic 中国社区官方博客17 小时前
我们如何在 Elasticsearch Serverless 上将向量搜索吞吐量提升一倍
大数据·数据库·人工智能·elasticsearch·搜索引擎·云原生·serverless
一 乐17 小时前
高校实习信息发布网站|基于Spring Boot的高校实习信息发布网站的设计与实现(源码+数据库+文档)
java·数据库·spring boot·后端·论文·毕设·高校实习信息发布网站
Dxy123931021617 小时前
三种方式避坑:案例 + 解决方法
python·mysql