GROUP BY变慢本质是无索引或索引未覆盖导致全表扫描、临时表和文件排序;判断覆盖需EXPLAIN中key显示索引且Extra无Using temporary/filesort,SELECT字段全在索引列中。为什么GROUP BY会突然变慢本质是数据库在分组时需要临时排序或哈希,如果 GROUP BY 字段没索引,或者索引无法覆盖查询字段,就会触发全表扫描 + 临时表 + 文件排序。常见现象是执行计划里出现 Using temporary; Using filesort。不是所有 GROUP BY 都慢------只有当分组字段无索引、或 SELECT 的字段超出索引列范围时,性能才会断崖式下跌。怎么判断当前SQL是否能走覆盖索引用 EXPLAIN 看 key 和 Extra 列:如果 key 显示用了某个索引,且 Extra 里没有 Using filesort 或 Using temporary,同时 SELECT 的所有字段(含 GROUP BY 列)都在该索引的定义列中,才算真正"覆盖"。GROUP BY a, b 时,索引必须是 (a, b) 或 (a, b, c) 这类左前缀结构,(b, a) 不行SELECT a, b, SUM(c) 要走覆盖,索引至少得是 (a, b, c);如果只建了 (a, b),c 还得回表查,不覆盖注意隐式类型转换:比如 user_id 是 BIGINT,但 WHERE user_id = '123' 传了字符串,索引就失效,覆盖自然也崩了建覆盖索引时最容易踩的三个坑覆盖索引不是字段堆得越多越好,顺序、冗余和维护成本都得算进去。 灵办AI 免费一键快速抠图,支持下载高清图片
相关推荐
coderwei12317 分钟前
从OpenAI到Strip:用六大支柱读懂Harness Engineering的生产实践海鸥-w29 分钟前
Python(FastAPI)中ORM框架Sqlalchemy的安装及建表爱喝水的鱼丶38 分钟前
SAP-ABAP:SAP基础数据校验工具开发系列博客(共5篇)第三篇:SAP接口对接开发:实现数据的实时/批量校验交互真香号1 小时前
记一次生产RocketMQ消息积压消费慢的排查与解决数据库小学妹1 小时前
国产数据库技术成熟度实测:从Oracle兼容到高可用,四个维度评估能不能上生产Wonderful U1 小时前
Python+Django实战|个人博客内容管理系统:搭建轻量化、高自由度的个人动态博客CMS系统JdSnE27zv1 小时前
数据库性能优化三:程序操作优化高洁011 小时前
智能体:你的私人数字助理海鸥-w1 小时前
python(fastapi) 实现更新,新增,删除接口淘矿人1 小时前
DeepSeek V4对决Claude 4.8:AI模型终极横评