Mysql如何执行GroupBy与Union

Mysql在进行分组或者子查询的过程中一般会使用到内部临时表的机制来帮助完成数据的统计,而group byunion在这个过程中,也可能会使用到内部临时表来完成数据的统计

Group By的执行流程

分组字段无索引
  • 执行语句

    select id%10 as m, count(*) as c from t1 group by m;

    这个简单的分组语句是将id%10分组进 行统计,并统计每个计算之后的数据的数量,并且会按照m的结果排序后输出。

    groupBy查询

    通过explain可以看到:

    • using temporary表示在执行分组的时候使用了临时表
    • using filesort表示使用了文件排序(可能是内存排序也可能借助了磁盘文件排序,取决于sort buffer是否可以放下查询到的数据)
  • 执行流程

    • 创建内存临时表,并且表里有2个字段,一个字段m,一个字段c,分别用来统计值和对应的数量,并且主键为m
    • 扫描t1表的索引a,依次取出叶子节点上的id值(这里不借助其他索引,在主键索引上可以直接完成,所以可以使用到覆盖索引),计算
  • 2
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值