Oracle分组函数之ROLLUP魅力

iamlaosong文

经常用Excel的人都知道分类汇总功能,rollup函数就可以实现这个分类汇总。以前都是简单的是用group by的分组功能,没想到还有这个rollup函数一说,试了一下,效果真的不错。rollup是对group by的扩展,因此,它只能出现在group by子句中,依赖于分组的列,对每个分组会生成汇总数据, rollup和group by联合一起使用,达到了按group by列顺序分组,并且实现小计和合计的功能。

类似的功能还有grouping sets和cube两个函数。grouping sets统计每个分组列,cube则统计分组列的每种组合。

rollup分组还是有序的,先全部分组,然后对每个分组小计,最后合计,使处理结果更清楚。rollup中列的顺序不同,则统计的结果不同,因为它是按列从右递减分组的,如下图:

再写一个例句,将空白的null换成小计和合计:

select nvl(to_char(qfrq,'yyyy-mm-dd'),'合计') qfrq,nvl(dsmc,'小计') dsmc,
      sum(case when zffs='微信' then zfje end),
      sum(case when zffs='支付宝' then zfje end),
      sum(case when zffs='预付卡' then zfje end),
      sum(case when zffs='邮储银行' then zfje end),
      sum(zfje)
  from EMSAPP_DZZF_JYMX
 where qfrq between to_date('2016-10-08', 'yyyy-mm-dd') and
       to_date('2016-10-14', 'yyyy-mm-dd')
   and jgsx like '%'
   and yjlx like '%'
 group by rollup(qfrq,dsmc);

下面是一篇介绍这个功能的网文,原文链接:http://blog.itpub.net/519536/viewspace-610995/

 

本文通过演示给出Oracle ROLLUP分组函数的用法,体验一下Oracle在统计查询领域中的函数魅力。ROLLUP分组函数可以理解为Group By分组函数封装后的精简用法,这里同时给出ROLLUP的Group By的改写思路。

1.初始化实验坏境
1)创建测试表group_test
SECOOLER@ora11g> create table group_test (group_id int, job varchar2(10), name varchar2(10), salary int);

Table created.

2)初始化数据
insert into group_test values (10,'Codin

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值