1.group by后带rollup子句
先按一定的规则产生多种分组,然后返回各个分组所产生的结果集的并集,且没有去掉重复数据(统计出的数据是求和还是最大值还是平均值等这就取决于SELECT后的聚合函数)。下面举例说明:
例1:Group by rollup(A ,B)
//返回如下3个分组的统计结果集的并集,且未去掉重复数据。 第一种:group by A,B 第二种:group by A 第三种:group by NULL (即没有分组,所有数据做一个统计)
例2:Group by rollup(A ,B,C)
//返回如下4种分组统计结果集的并集,且未去掉重复数据 第一种:group by A,B,C 第二种:group by A,B 第三种:group by A 第四种:group by NULL
例3:Group by C , rollup(A ,B)
//group by和rollup间还有其它列C,返回如下3种分组统计结果集的并集,且未去掉重复数据 第一种:group by C,A,B 第二种:group by C,A 第三种:group by C,NULL 等价于group by C
例4:Group by rollup(A ,(B,C))
//多列被括号括在一起时,视为一个整体。返回如下3中分组统计结果的并集,且未去掉重复数据 第一种:group by A,B,C 第二种:group by A 第三种:group by NULL
参考文档:
group by后加rollup子句的用法以及与cube和grouping sets子句的区别
原文地址:https://www.cnblogs.com/badboy200800/p/10404279.html
时间: 2024-11-14 12:34:27