ITPub博客

首页 > Linux操作系统 > Linux操作系统 > oracle group by的按照不同粒度聚合方法

oracle group by的按照不同粒度聚合方法

原创 Linux操作系统 作者:regonly1 时间:2012-05-07 14:57:37 0 删除 编辑
一直以为group by 除了rollup和cube可以按照子句中指定的字段进行不同粒度的聚合,没有其他的方法了。今天因为groupby的bug(hash group b y)而发现了另一种方法,如下例:
with tmp as(
    select '0001' userno, '01' pno from dual union all
    select '0001' userno, '01' pno from dual union all
    select '0001' userno, '02' pno from dual union all
    select '0002' userno, '01' pno from dual union all
    select '0002' userno, '03' pno from dual union all
    select '0003' userno, '03' pno from dual)
select grouping_id(userno, pno) gid, userno, pno, count(1) cnt
  from tmp
 group by grouping sets((), (userno), (userno, pno))
其意义在于,我如果需要按照指定粒度进行汇总,而不用rollup或cube那种全组合的粒度,就可以用这种方式。

参考文档连接:
http://wenku.baidu.com/view/5150fd7ea26925c52cc5bff7.html

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/12932950/viewspace-722900/,如需转载,请注明出处,否则将追究法律责任。

请登录后发表评论 登录
全部评论

注册时间:2008-05-10

  • 博文量
    257
  • 访问量
    1015462