MySQL分组优化

分组优化

在使用group by进行分组时,实际上也需要进行排序操作,与order by相比,group by主要是多了排序之后的分组操作

group by的实现有三种方式

  • 使用松散索引扫描实现group by

  • 使用紧凑索引扫描实现group by

使用松散索引扫描实现group by

MySQL完全利用索引扫描来实现group by

在使用explain执行计划时extra字段中出现using index for group by表示使用了松散索引扫描实现的group by操作

需要满足的条件

  • group by条件字段必须在同一个索引中最前面的连续位置
  • 在使用group by的同时,只能使用min和max这两个聚合函数
  • 如果用到了该索引中group by条件之外的字段条件时,必须以常量形式存在

使用紧凑索引扫描实现group by

紧凑索引与松散索引的区别主要在于需要在扫描索引的时候,读取所有满足条件的索引键,然后根据读取到的数据来完成group by操作得到相应的结果

MySQL会先尝试使用松散索引扫描实现group by,当发现条件不满足时,才会尝试使用紧凑索引扫描

当group by条件字段并不连续或者不是索引前缀部分的时候,无法使用松散索引扫描,才会尝试使用紧凑索引扫描来实现

使用临时表实现group by

MySQL在进行group by操作的时候要想利用索引,必须满足group by的字段必须同时存放于同一个索引,且该索引是一个有序索引,如果无法找到合适的索引可以利用的时候,就不得不先读取需要的数据,然后通过临时表来完成group by操作

zhhll.icu/2021/数据库/关系...

本文由mdnice多平台发布

相关推荐
剩下了什么12 分钟前
MySQL JSON_SET() 函数
数据库·mysql·json
山峰哥42 分钟前
数据库工程与SQL调优——从索引策略到查询优化的深度实践
数据库·sql·性能优化·编辑器
较劲男子汉1 小时前
CANN Runtime零拷贝传输技术源码实战 彻底打通Host与Device的数据传输壁垒
运维·服务器·数据库·cann
java搬砖工-苤-初心不变1 小时前
MySQL 主从复制配置完全指南:从原理到实践
数据库·mysql
山岚的运维笔记3 小时前
SQL Server笔记 -- 第18章:Views
数据库·笔记·sql·microsoft·sqlserver
roman_日积跬步-终至千里4 小时前
【LangGraph4j】LangGraph4j 核心概念与图编排原理
java·服务器·数据库
汇智信科4 小时前
打破信息孤岛,重构企业效率:汇智信科企业信息系统一体化运营平台
数据库·重构
野犬寒鸦4 小时前
从零起步学习并发编程 || 第六章:ReentrantLock与synchronized 的辨析及运用
java·服务器·数据库·后端·学习·算法
晚霞的不甘5 小时前
揭秘 CANN 内存管理:如何让大模型在小设备上“轻装上阵”?
前端·数据库·经验分享·flutter·3d
市场部需要一个软件开发岗位6 小时前
JAVA开发常见安全问题:纵向越权
java·数据库·安全