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),
COUNT(DISTINCT diag_code),
GROUPING(p_code),
GROUPING(MONTH)
FROM T1
WHERE p_code <= 100013
GROUP BY rollup(p_code,MONTH);

本文介绍了Oracle中的GROUPING和GROUPING_ID函数,这两个函数常与GROUP BY ROLLUP或CUBE结合使用,用于实现数据汇总。GROUPING函数在字段为NULL时返回1,否则返回0,而GROUPING_ID则可以一次判断多个字段的汇总状态。通过示例代码,文章展示了如何使用这些函数简化SQL代码,以更清晰地呈现小计和总计。最后,给出了两个实际应用场景,说明了在统计分析中的具体应用。
最低0.47元/天 解锁文章
1092

被折叠的 条评论
为什么被折叠?



