SQL中rollup和cube分组函数用法及示例分析

发布时间:2022-01-17 11:35:07 作者:柒染
来源:亿速云 阅读:278

SQL中rollup和cube分组函数用法及示例分析,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。

首先,它计算GROUP BY子句中指定的标准聚合值。

然后,它会逐步创建更高级别的小计,在分组列列表中从右向左移动。

最后,它创造了一个总数。

N+1个次超集料组合。

从gc.test中选择GROUPING(所有者)、GROUPING(对象类型)、OWNER、OBJECT_TYPE、COUNT(*。

按汇总分组(OWNER,OBJECT_TYPE)。

按业主订购;

先对owner,object_type分组,再对owner分组(也就是小计),最后再合计,

grouping可看到小计级别。 

如果rollup(a,b,c),那就先对a,b,c分组,再对a,b分组,再对a分组,最后再合计。

 

cube

cube(a,b,c),顺序先a,b,c 再a,b 再a,c a b,c b c 再合計

It produces 2n次方 possible superaggregate combinations, if the n columns and expressions are specified in the GROUP BY clause.

注:The HAVING,GROUP BY clause conditions can’t use aliases for the columns.

        But ORDER BY clause can use aliases.



SQL一例,按分钟先小计,再按小时合计:
select grouping(TO_CHAR(CREATED,'yyyy-mm-dd hh34')),grouping(TO_CHAR(CREATED,'yyyy-mm-dd hh34:mi')),
TO_CHAR(CREATED,'yyyy-mm-dd hh34'),TO_CHAR(CREATED,'yyyy-mm-dd hh34:mi'),count(1) from dba_objects
group by rollup(TO_CHAR(CREATED,'yyyy-mm-dd hh34'),TO_CHAR(CREATED,'yyyy-mm-dd hh34:mi'))
order by TO_CHAR(CREATED,'yyyy-mm-dd hh34')

关于SQL中rollup和cube分组函数用法及示例分析问题的解答就分享到这里了,希望以上内容可以对大家有一定的帮助,如果你还有很多疑惑没有解开,可以关注亿速云行业资讯频道了解更多相关知识。

推荐阅读:
  1. rollup函数 和cube函数 的区别?
  2. 高级分组group by 、 group by cube、 group by rollup 使用说明

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

sql rollup cube

上一篇:web开发中如何实现堆排序

下一篇:如何进行Java中守护线程的分析及使用

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》