Oracle PL/SQL之GROUP BY GROUPING SETS
[转自] http://blog.csdn.net/t0nsha/article/details/6538838
使用GROUP BY GROUPING SETS相当于把需要GROUP的集合用UNION ALL联合起来。
当GROUPING SETS里面的分组元素越多时,使用GROUPING SETS比使用UNION ALL性能更好,这可能和使用GROUPING SETS只需要访问一次表有关。
如下两段查询的结果是相等的:
q1(GROUPING SETS):
- SELECT department_id, job_id, manager_id, AVG (salary)
- FROM employees
- GROUP BY GROUPING SETS ((department_id, job_id), (job_id, manager_id));
- DEPARTMENT_ID JOB_ID MANAGER_ID AVG(SALARY)
- ------------- ---------- ---------- -----------
- SH_CLERK 122 3200
- AC_MGR 101 12000
- ST_MAN 100 7280
- ST_CLERK 121 2675
- SA_REP 148 8650
- SH_CLERK 120 2900
- SH_CLERK 124 2825
- MK_MAN 100 13000
- AD_PRES 24000
- FI_MGR 101 12000
- SA_REP 146 8500
- SH_CLERK 123 3475
- AD_ASST 101 4400
- IT_PROG 102 9000
- IT_PROG 103 4950
- FI_ACCOUNT 108 7920
- PU_MAN 100 11000
- ST_CLERK 122 2700
- SA_REP 145 8500
- AC_ACCOUNT 205 8300
- AD_VP 100 17000
- DEPARTMENT_ID JOB_ID MANAGER_ID AVG(SALARY)
- ------------- ---------- ---------- -----------
- ST_CLERK 120 2625
- ST_CLERK 124 2925
- SA_REP 147 7766.66667
- SA_REP 149 8333.33333
- HR_REP 101 6500
- PR_REP 101 10000
- ST_CLERK 123 3000
- SH_CLERK 121 3675
- PU_CLERK 114 2780
- SA_MAN 100 12200
- MK_REP 201 6000
- 110 AC_ACCOUNT 8300
- 90 AD_VP 17000
- 50 ST_CLERK 2785
- 80 SA_REP 8396.55172
- 50 ST_MAN 7280
- 80 SA_MAN 12200
- 110 AC_MGR 12000
- 90 AD_PRES 24000
- 60 IT_PROG 5760
- 100 FI_MGR 12000
- DEPARTMENT_ID JOB_ID MANAGER_ID AVG(SALARY)
- ------------- ---------- ---------- -----------
- 30 PU_CLERK 2780
- 50 SH_CLERK 3215
- 20 MK_MAN 13000
- 100 FI_ACCOUNT 7920
- SA_REP 7000
- 70 PR_REP 10000
- 30 PU_MAN 11000
- 10 AD_ASST 4400
- 20 MK_REP 6000
- 40 HR_REP 6500
- 52 rows selected.
SELECT department_id, job_id, manager_id, AVG (salary)
FROM employees
GROUP BY GROUPING SETS ((department_id, job_id), (job_id, manager_id));
DEPARTMENT_ID JOB_ID MANAGER_ID AVG(SALARY)
------------- ---------- ---------- -----------
SH_CLERK 122 3200
AC_MGR 101 12000
ST_MAN 100 7280
ST_CLERK 121 2675
SA_REP 148 8650
SH_CLERK 120 2900
SH_CLERK 124 2825
MK_MAN 100 13000
AD_PRES 24000
FI_MGR 101 12000
SA_REP 146 8500
SH_CLERK 123 3475
AD_ASST 101 4400
IT_PROG 102 9000
IT_PROG 103 4950
FI_ACCOUNT 108 7920
PU_MAN 100 11000
ST_CLERK 122 2700
SA_REP 145 8500
AC_ACCOUNT 205 8300
AD_VP 100 17000
DEPARTMENT_ID JOB_ID MANAGER_ID AVG(SALARY)
------------- ---------- ---------- -----------
ST_CLERK 120 2625
ST_CLERK 124 2925
SA_REP 147 7766.66667
SA_REP 149 8333.33333
HR_REP 101 6500
PR_REP 101 10000
ST_CLERK 123 3000
SH_CLERK 121 3675
PU_CLERK 114 2780
SA_MAN 100 12200
MK_REP 201 6000
110 AC_ACCOUNT 8300
90 AD_VP 17000
50 ST_CLERK 2785
80 SA_REP 8396.55172
50 ST_MAN 7280
80 SA_MAN 12200
110 AC_MGR 12000
90 AD_PRES 24000
60 IT_PROG 5760
100 FI_MGR 12000
DEPARTMENT_ID JOB_ID MANAGER_ID AVG(SALARY)
------------- ---------- ---------- -----------
30 PU_CLERK 2780
50 SH_CLERK 3215
20 MK_MAN 13000
100 FI_ACCOUNT 7920
SA_REP 7000
70 PR_REP 10000
30 PU_MAN 11000
10 AD_ASST 4400
20 MK_REP 6000
40 HR_REP 6500
52 rows selected.
q2(UNION ALL):
- SELECT NULL department_id, job_id, manager_id, AVG (salary)
- FROM employees
- GROUP BY (job_id, manager_id)
- UNION ALL
- SELECT department_id, job_id, NULL manager_id, AVG (salary)
- FROM employees
- GROUP BY (department_id, job_id);
- DEPARTMENT_ID JOB_ID MANAGER_ID AVG(SALARY)
- ------------- ---------- ---------- -----------
- SH_CLERK 122 3200
- AC_MGR 101 12000
- ST_MAN 100 7280
- ST_CLERK 121 2675
- SA_REP 148 8650
- SH_CLERK 120 2900
- SH_CLERK 124 2825
- MK_MAN 100 13000
- AD_PRES 24000
- FI_MGR 101 12000
- SA_REP 146 8500
- SH_CLERK 123 3475
- AD_ASST 101 4400
- IT_PROG 102 9000
- IT_PROG 103 4950
- FI_ACCOUNT 108 7920
- PU_MAN 100 11000
- ST_CLERK 122 2700
- SA_REP 145 8500
- AC_ACCOUNT 205 8300
- AD_VP 100 17000
- DEPARTMENT_ID JOB_ID MANAGER_ID AVG(SALARY)
- ------------- ---------- ---------- -----------
- ST_CLERK 120 2625
- ST_CLERK 124 2925
- SA_REP 147 7766.66667
- SA_REP 149 8333.33333
- HR_REP 101 6500
- PR_REP 101 10000
- ST_CLERK 123 3000
- SH_CLERK 121 3675
- PU_CLERK 114 2780
- SA_MAN 100 12200
- MK_REP 201 6000
- 110 AC_ACCOUNT 8300
- 90 AD_VP 17000
- 50 ST_CLERK 2785
- 80 SA_REP 8396.55172
- 50 ST_MAN 7280
- 80 SA_MAN 12200
- 110 AC_MGR 12000
- 90 AD_PRES 24000
- 60 IT_PROG 5760
- 100 FI_MGR 12000
- DEPARTMENT_ID JOB_ID MANAGER_ID AVG(SALARY)
- ------------- ---------- ---------- -----------
- 30 PU_CLERK 2780
- 50 SH_CLERK 3215
- 20 MK_MAN 13000
- 100 FI_ACCOUNT 7920
- SA_REP 7000
- 70 PR_REP 10000
- 30 PU_MAN 11000
- 10 AD_ASST 4400
- 20 MK_REP 6000
- 40 HR_REP 6500
- 52 rows selected.
Oracle PL/SQL之GROUP BY GROUPING SETS的更多相关文章
- Oracle的rollup、cube、grouping sets函数
转载自:https://blog.csdn.net/huang_xw/article/details/6402396 Oracle的group by除了基本用法以外,还有3种扩展用法,分别是rollu ...
- ORACLE PL/SQL编程详解
ORACLE PL/SQL编程详解 编程详解 SQL语言只是访问.操作数据库的语言,并不是一种具有流程控制的程序设计语言,而只有程序设计语言才能用于应用软件的开发.PL /SQL是一种高级数据库程序设 ...
- ORACLE PL/SQL编程之八:把触发器说透
原文:ORACLE PL/SQL编程之八:把触发器说透 ORACLE PL/SQL编程之八: 把触发器说透 大家一定要评论呀,感谢!光发表就花了我将近一个下午. 本篇主要内容如下: 8.1 触发器类型 ...
- [转]详解Oracle高级分组函数(ROLLUP, CUBE, GROUPING SETS)
原文地址:http://blog.csdn.net/u014558001/article/details/42387929 本文主要讲解 ROLLUP, CUBE, GROUPING SETS的主要用 ...
- ORACLE PL/SQL编程详解(转)
原帖地址:http://blog.csdn.net/chenjinping123/article/details/8737604 ORACLE PL/SQL编程详解 SQL语言只是访问.操作数据库的语 ...
- ORACLE PL/SQL:触发器
ORACLE PL/SQL 触发器 本篇主要内容如下: 8.1 触发器类型 8.1.1 DML触发器 8.1.2 替代触发器 8.1.3 系统触发器 8.2 创建触发器 8.2.1 触发器触发次序 8 ...
- group by <grouping sets(...) ><cube(...)>
GROUP BY GROUPING SETS() 后面将还会写学习 with cube, with rollup,以及将它们转换为标准的GROUP BY的子句GROUP SET(), CU ...
- [强烈推荐]ORACLE PL/SQL编程详解之七:程序包的创建与应用(聪明在于学习,天才在于积累!)
原文:[强烈推荐]ORACLE PL/SQL编程详解之七:程序包的创建与应用(聪明在于学习,天才在于积累!) [强烈推荐]ORACLE PL/SQL编程详解之七: 程序包的创建与应用(聪明在于学习,天 ...
- [推荐]ORACLE PL/SQL编程之五:异常错误处理(知已知彼、百战不殆)
原文:[推荐]ORACLE PL/SQL编程之五:异常错误处理(知已知彼.百战不殆) [推荐]ORACLE PL/SQL编程之五: 异常错误处理(知已知彼.百战不殆) 继上三篇:ORACLE PL/S ...
随机推荐
- 26.COUNT() 函数
COUNT() 函数返回匹配指定条件的行数. SQL COUNT() 语法 SQL COUNT(column_name) 语法 COUNT(column_name) 函数返回指定列的值的数目(NULL ...
- 二度Xml<2>
一下介绍xml的基本操作,添加xml新节点: 其他方法在前一篇日记中有详细讲解,请详见:http://www.cnblogs.com/fjsnail/archive/2012/10/20/273212 ...
- Win7 WPF程序无法接受外部拖拽
最近在WPF项目中遇到一个问题.虽然选择了AllowDrop = True,但是还是无法支持从外部拖拽文件到程序,倒是内部拖拽(如从一个列表拖拽到树)和从程序拖拽到外部可以. 解决过程 1.考虑是程序 ...
- Android 学习笔记 文本文件的读写操作
activity_main.xml <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android&qu ...
- 严选 Android 路由框架优化(上篇)
0 背景 早前严选 Android 工程,使用原生 Intent 方式做页面跳转,为规范参数传递,做了编码规范,使用静态方法的方式唤起 Activity public static void star ...
- 汇编工具安装二:RadASM的安装!
已经配置好的汇编工具下载地址:http://download.csdn.net/detail/sunylat/9189543 RadASM也是一款汇编开发工具,网址:http://www.oby.ro ...
- 原码、反码、补码及位操作符,C语言位操作
计算机中的所有数据均是以二进制形式存储和处理的.所谓位操作就是直接把计算机中的二进制数进行操作,无须进行数据形式的转换,故处理速度较快. 1.原码.反码和补码 位(bit) 是计算机中处理数据的最小单 ...
- 如何处理html中的内联元素之间水平空隙
写HTML时把需要紧挨着的内联元素写在一行,设置其父容器的font-size为0,再设置内联元素的字体大小,例如: <!DOCTYPE html> <html lang=" ...
- 【BZOJ2159】Crash的文明世界 斯特林数+树形dp
Description Crash 小朋友最近迷上了一款游戏--文明5(Civilization V).在这个游戏中,玩家可以建立和发展自己的国家,通过外交和别的国家交流,或是通过战争征服别的国家.现 ...
- 【离散数学】 SDUT OJ 建图
建图 Time Limit: 1000 ms Memory Limit: 65536 KiB Submit Statistic Problem Description 编程使得程序可以接受一个图的点边 ...