mysql group原理_mysql group by执行原理

本文详细解析了MySQL中GROUP BY的三种实现方式:松散索引、紧凑索引和临时文件排序,并探讨了如何通过索引优化GROUP BY操作。强调了GROUP BY必须与最左前缀索引匹配才能有效利用索引,并解释了为什么不能在GROUP BY语句中使用SELECT *。
摘要由CSDN通过智能技术生成

mysql中group by实现方式有三种,松散索引,紧凑索引,临时文件(文件排序)。

在网上看了相关的介绍,大部分介绍都比较晦涩难懂,这里说下我的理解。

在学习SQL优化时,我们都知道可以对group by进行优化的方式就是对group by引用的字段建立索引。当group by引用多个字段时,我们建立的相应的索引也应包含多个字段。

对group by操作优化的原理就是让mysql利用索引,而避免进行建立临时表,进而进行文件排序(group by的第三种实现方式)。

对于group by引用的多个字段,需满足于所建立索引的最左前缀索引,否则进行group by操作时,无法利用索引。在利用索引时,group by可根据索引,即可对数据分组,此时完全不用去

访问表的数据值(索引健对应的数据)。这种实现方式就是利用松散索引。

当group by引用的字段无法构成所建索引的最左前缀索引时,也就是说group by不能利用索引时。如何where语句(如果有的话)弥补了这种差距,比如:group by

引用的字段为(c2,c3),而索引为(c1,c2,c3)。此时如果where语句限定了c1=a(某一个值),那么此时mysql的执行过程为先根据where语句进行一次选择,

对选出来的结果集,可以利用索引。这种方式,从整体上来说,group by并没有利用索引,但是从过程来说,在选出的结果中利用了索引,这种方式就是紧凑索引。

这种方式,mysql的执行计划为using where,use index。而松散索引的执行

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值