Oracle公司内部数据库培训资料17_对_GROUP_BY_子句的扩展
对 GROUP BY 子句的扩展
Copyright © Oracle Corporation, 2001. All rights reserved.
目标
通过本章学习,您将可以:
使用 ROLLUP 操作分组 使用 CUBE 操作分组 使用 GROUPING 函数处理 ROLLUP 或 CUBE操作所产 生的空值 使用 GROUPING SETS 操作进行单独分组
17-2
Copyright © Oracle Corporation, 2001. All rights reserved.
组函数组函数处理多行返回一个行SELECT FROM [WHERE [GROUP BY [ORDER BY [column,] group_function(column). . . table condition] group_by_expression] column];
例子:SELECT AVG(salary), STDDEV(salary), COUNT(commission_pct),MAX(hire_date) FROM employees WHERE job_id LIKE 'SA%';
17-3
Copyright © Oracle Corporation, 2001. All rights reserved.
GROUP BY 子句语法:SELECT FROM [WHERE [GROUP BY [ORDER BY [column,] group_function(column). . . table condition] group_by_expression] column];
例子:SELECT department_id, job_id, SUM(salary), COUNT(employee_id) FROM employees GROUP BY department_id, job_id ;
17-4
Copyright © Oracle Corporation, 2001. All rights reserved.
HAVING 子句SELECT FROM [WHERE [GROUP BY [HAVING [ORDER BY [column,] group_function(column)... table condition] group_by_expression] having_expression] column];
使用 HAVING 对组函数进行限制 对查询进行第二次限制
17-5
Copyright © Oracle Corporation, 2001. All rights reserved.
带有ROLLUP 和 CUBE 操作的GROUP BY 子句 使用带有ROLLUP 和 CUBE 操作的GROUP BY 子句产生 多种分组结果 ROLLUP 产生n + 1种分组结果
CUBE 产生2的n次方种分组结果
17-6
Copyright © Oracle Corporation, 2001. All rights reserved.
ROLLUP 操作符SELECT FROM [WHERE [GROUP BY [HAVING [ORDER BY [column,] group_function(column). . . table condition] [ROLLUP] group_by_expression] having_expression]; column];
ROLLUP 是对 GROUP BY 子句的扩展ROLLUP 产生n + 1种分组结果,顺序是从右向左
17-7
Copyright © Oracle Corporation, 2001. All rights reserved.
ROLLUP 应用举例SELECT FROM WHERE GROUP BY department_id, job_id, SUM(salary) employees department_id < 60 ROLLUP(department_id, job_id);
1
2
3
17-8
Copyright © Oracle Corporation, 2001. All rights reserved.
CUBE 操作符
SELECT FROM [WHERE [GROUP BY [HAVING [ORDER BY
[column,] group_function(column)... table condition] [CUBE] group_by_expression] having_expression] column];
CUBE是对 GROUP BY 子句的扩展 CUBE 会产生类似于笛卡尔集的分组结果
17-9
Copyright © Oracle Corporation, 2001. All rights reserved.
CUBE 应用举例SELECT FROM WHERE GROUP BY department_id, job_id, SUM(salary) employees department_id < 60 CUBE (department_id, job_id) ;
1 2
3
4
17-10
Copyright © Oracle Corporation, 2001. All rights reserved.
GROUPING 函数SELECT [column,] group_function(column) . , GROUPING(expr) FROM table [WHERE condition] [GROUP BY [ROLLUP][CUBE] group_by_expression] [HAVING having_expression] [ORDER BY
column];
GROUPING 函数可以和 CUBE 或 ROLLUP 结合使用 使用 GROUPING 函数,可以找到哪些列在该行中参加 了分组 使用 GROUPING 函数, 可以区分空值产生的原因 GROUPING 函数返回 0 或 1
17-11
Copyright © Oracle Corporation, 2001. All rights reserved.
GROUPING 函数举例SELECT department_id DEPTID, job_id JOB, SUM(salary), GROUPING(department_id) GRP_DEPT, GROUPING(job_id) GRP_JOB FROM employees WHERE department_id < 50 GROUP BY ROLLUP(department_id, job_id);
1
23
17-12
Copyright © Oracle Corporation, 2001. All rights reserved.
GROUPING SETS GROUPING SETS 是对GROUP BY 子句的进一步扩充 使用 GROUPING SETS 在同一个查询中定义多个分组集 Oracle 对 GROUPING SETS 子句指定的分组集进行分组后 用 UNION ALL 操作将各分组结果结合起来
Grouping set 的优点:– 只进行一次分组即可 – 不必书写复杂的 UNION 语句 – GROUPING SETS 中包含的分组项越多,性能越好。
17-13
Copyright © Oracle Corporation, 2001. All rights reserved.
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));
1
…2
17-14
Copyright © Oracle Corporation, 2001. All rights reserved.
复合列
复合列是被作为整体处理的一组列的集合ROLLUP (a,(b,c), d)
使用括号将若干列组成复合列在ROLLUP 或 CUBE 中作 为整体进行操作 在ROLLUP 或 CUBE中, 复合列可以避免产生不必要的分 组结果
17-15
Copyright © Oracle Corporation, 2001. All rights reserved.
复合列应用举例
SELECT
department_id, job_id, manager_id, SUM(salary) FROM employees GROUP BY ROLLUP( department_id,(job_id, manager_id));
1
2
…3
17-16
Copyright © Oracle Corporation, 2001. All rights reserved.
…… 此处隐藏:1949字,全部文档内容请下载后查看。喜欢就下载吧 ……相关推荐:
- [实用模板]第八章:法国“新浪潮”与“左岸派”
- [实用模板]2021年北京上半年临床医学检验技师生物
- [实用模板]SAP GUI 7.10客户端安装配置文档
- [实用模板]2001年临床执业医师资格考试综合笔试试
- [实用模板]36机场工作实用英语词汇总结
- [实用模板](一)社会保险稽核通知书
- [实用模板]安全教育主题班会材料
- [实用模板]濉溪县春季呼吸道传染病防控应急演练方
- [实用模板]长沙房地产市场周报(1.30-2.3)
- [实用模板]六年级数学上册典中点 - 图文
- [实用模板]C程序设计(红皮书)习题官方参考答案
- [实用模板]中国证监会第一届创业板发行审核委员会
- [实用模板]桥梁工程复习题
- [实用模板]2011学而思数学及答案
- [实用模板]初中病句修改专项练习
- [实用模板]监理学习知识1 - 图文
- [实用模板]小机灵杯四年级试题
- [实用模板]国贸专业毕业论文模板
- [实用模板]教育学概论考试练习题-判断题4
- [实用模板]2015届高考英语一轮复习精品资料(译林
- 00Nkmhe_市场营销学工商管理_电子商务_
- 事业单位考试法律常识
- 诚信教育实施方案
- 吉大小天鹅食品安全检测箱方案(高中低
- 房地产销售培训资料
- 高一地理必修1复习提纲
- 新概念英语第二册lesson_1_练习题
- 证券公司内部培训资料
- 小学英语时间介词专项练习
- 新世纪英语专业综合教程(第二版)第1册U
- 【新课标】浙教版最新2018年八年级数学
- 工程建设管理纲要
- 外研版 必修一Module 4 A Social Surve
- Adobe认证考试 AE复习资料
- 基于H.264AVC与AVS标准的帧内预测技术
- 《食品检验机构资质认定管理办法》(质
- ABB变频器培训课件
- (完整版)小学说明文阅读练习题及答案
- 深思洛克(SenseLock) 深思IV,深思4,深
- 弟子规全文带拼音




