视频1 视频21 视频41 视频61 视频文章1 视频文章21 视频文章41 视频文章61 推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37 推荐39 推荐41 推荐43 推荐45 推荐47 推荐49 关键词1 关键词101 关键词201 关键词301 关键词401 关键词501 关键词601 关键词701 关键词801 关键词901 关键词1001 关键词1101 关键词1201 关键词1301 关键词1401 关键词1501 关键词1601 关键词1701 关键词1801 关键词1901 视频扩展1 视频扩展6 视频扩展11 视频扩展16 文章1 文章201 文章401 文章601 文章801 文章1001 资讯1 资讯501 资讯1001 资讯1501 标签1 标签501 标签1001 关键词1 关键词501 关键词1001 关键词1501 专题2001
ORACLEGROUPING函数的使用
2020-11-09 08:26:50 责编:小采
文档


欢迎进入Oracle社区论坛,与200万技术人员互动交流 >>进入 GROUPING函数可以接受一列,返回0或者1。如果列值为空,那么GROUPING()返回1;如果列值非空,那么返回0。GROUPING只能在使用ROLLUP或CUBE的查询中使用。当需要在返回空值的地方显示某个值时,GROU

欢迎进入Oracle社区论坛,与200万技术人员互动交流 >>进入

GROUPING函数可以接受一列,返回0或者1。如果列值为空,那么GROUPING()返回1;如果列值非空,那么返回0。GROUPING只能在使用ROLLUP或CUBE的查询中使用。当需要在返回空值的地方显示某个值时,GROUPING()就非常有用。

关于ROLLUP和CUBE函数的使用,请参见我的另一篇文章。

1、在ROLLUP中对单列使用GROUPING()

SQL> select division_id,sum(salary)

2 from employees2

3 group by rollup(division_id)

4 order by division_id;

DIV SUM(SALARY)

--- -----------

BUS 1610000

OPE 1320000

SAL 4936000

SUP 1015000

8881000

加上GROUPING来看看

SQL> select grouping(division_id),division_id,sum(salary)

2 from employees2

3 group by rollup(division_id)

4 order by division_id;

GROUPING(DIVISION_ID) DIV SUM(SALARY)

--------------------- --- -----------

0 BUS 1610000

0 OPE 1320000

0 SAL 4936000

0 SUP 1015000

1 8881000

可以看到,为空的地方返回1,非空的地方返回0。

2、使用CASE转换GROUPING()的返回值

可能你会觉得前面的0和1太枯燥了,代表不了任何意义,说白了就是不够人性化,呵呵。这个时候我们可以使用CASE来转换为一些有意义的值。

SQL> select

2 case grouping(division_id)

3 when 1 then 'all divisions'

4 else division_id

5 end as div,

6 sum(salary)

7 from employees2

8 group by rollup(division_id)

9 order by division_id;

DIV SUM(SALARY)

------------- -----------

BUS 1610000

OPE 1320000

SAL 4936000

SUP 1015000

all divisions 8881000

3、使用CASE和GROUPING()转换多个列的值

SQL> select

2 case grouping(division_id)

3 when 1 then 'all divisions'

4 else division_id

5 end as div,

6 case grouping(job_id)

7 when 1 then 'all jobs'

8 else job_id

9 end as job,

10 sum(salary)

11 from employees2

12 group by rollup(division_id,job_id)

13 order by division_id,job_id;

DIV JOB SUM(SALARY)

------------- -------- -----------

BUS MGR 530000

BUS PRE 800000

BUS WOR 280000

BUS all jobs 1610000

OPE ENG 245000

OPE MGR 805000

OPE WOR 270000

[1] [2]

下载本文
显示全文
专题