日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

grouping Function

發(fā)布時間:2025/3/20 编程问答 45 豆豆
生活随笔 收集整理的這篇文章主要介紹了 grouping Function 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

轉自:

http://blog.csdn.net/xiadingling/article/details/7876120


GROUPING函數(shù)可以接受一列,返回0或者1。如果列值為空,那么GROUPING()返回1;如果列值非空,那么返回0。GROUPING只能在使用ROLLUP或CUBE的查詢中使用。當需要在返回空值的地方顯示某個值時,GROUPING()就非常有用。

?

關于ROLLUP和CUBE函數(shù)的使用,請參見我的另一篇文章。

http://blog.csdn.net/wh62592855/archive/2009/11/16/4817920.aspx

?

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
OPE?????????? all jobs???? 1320000
SAL?????????? MGR????????? 4446000
SAL?????????? WOR?????????? 490000
SAL?????????? all jobs???? 4936000

DIV?????????? JOB????? SUM(SALARY)
------------- -------- -----------
SUP?????????? MGR?????????? 465000
SUP?????????? TEC?????????? 115000
SUP?????????? WOR?????????? 435000
SUP?????????? all jobs???? 1015000
all divisions all jobs???? 8881000

16 rows selected.

?

4、CUBE與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 cube(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
OPE?????????? all jobs???? 1320000
SAL?????????? MGR????????? 4446000
SAL?????????? WOR?????????? 490000
SAL?????????? all jobs???? 4936000

DIV?????????? JOB????? SUM(SALARY)
------------- -------- -----------
SUP?????????? MGR?????????? 465000
SUP?????????? TEC?????????? 115000
SUP?????????? WOR?????????? 435000
SUP?????????? all jobs???? 1015000
all divisions ENG?????????? 245000
all divisions MGR????????? 6246000
all divisions PRE?????????? 800000
all divisions TEC?????????? 115000
all divisions WOR????????? 1475000
all divisions all jobs???? 8881000

21 rows selected.

?

5、使用GROUPING SETS子句

使用GROUPING SETS子句可以只返回小計記錄。

SQL> select division_id,job_id,sum(salary)
? 2? from employees2
? 3? group by grouping sets(division_id,job_id)
? 4? order by division_id,job_id;

DIV JOB SUM(SALARY)
--- --- -----------
BUS???????? 1610000
OPE???????? 1320000
SAL???????? 4936000
SUP???????? 1015000
??? ENG????? 245000
??? MGR???? 6246000
??? PRE????? 800000
??? TEC????? 115000
??? WOR???? 1475000

9 rows selected.

總結

以上是生活随笔為你收集整理的grouping Function的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。