Oracle函数之聚合函数---1、关于grouping与grouping_id

1、作用

grouping与grouping_id都是和group by rollup或group by cube同时出现的,实现了小计与总计的功能。

2、引入此函数目的

在小计与总计的字段,往往是NULL值,因此不容易区分并且写SQL时不美观且麻烦。

3、注意

grouping与grouping_id的字段,必须是group by的字段;

与rollup或cube关键字一同出现;

当字段为NULL时,grouping返回1,否则返回0;

当字段的后续列为NULL时,grouping_id返回1,当字段的前导列为NULL时,grouping_id返回2(仅当cube才出现此种情况),如果全部为NULL,则返回3,如果全不为NULL,则返回0.

3、示例

3.1、grouping

grouping函数的官方解释链接如下(11gR2):

http://docs.oracle.com/cd/E11882_01/server.112/e41084/functions071.htm#SQLRF00647


代码1:

SELECT p_code,
       MONTH,
       COUNT(DISTINCT t_code),
    
  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值