已阅读5页,还剩22页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
,对 GROUP BY 子句的扩展,目标,通过本章学习,您将可以: 使用 ROLLUP 操作分组 使用 CUBE 操作分组 使用 GROUPING 函数处理 ROLLUP 或 CUBE操作所产生的空值 使用 GROUPING SETS 操作进行单独分组,组函数,组函数处理多行返回一个行,SELECT column, group_function(column). . . FROM table WHERE condition GROUP BY group_by_expression ORDER BY column;,SELECT AVG(salary), STDDEV(salary), COUNT(commission_pct),MAX(hire_date) FROM employees WHERE job_id LIKE SA%;,例子:,GROUP BY 子句,SELECT department_id, job_id, SUM(salary), COUNT(employee_id) FROM employees GROUP BY department_id, job_id ;,SELECT column, FROM table WHERE condition GROUP BY group_by_expression ORDER BY column;,例子:,语法:,group_function(column). . .,HAVING 子句,使用 HAVING 对组函数进行限制 对查询进行第二次限制,SELECT column, group_function(column). FROM table WHERE condition GROUP BY group_by_expression HAVING having_expression ORDER BY column;,带有ROLLUP 和 CUBE 操作的GROUP BY 子句,使用带有ROLLUP 和 CUBE 操作的GROUP BY 子句产生多种分组结果 ROLLUP 产生n + 1种分组结果 CUBE 产生2的n次方种分组结果,ROLLUP 操作符,ROLLUP 是对 GROUP BY 子句的扩展 ROLLUP 产生n + 1种分组结果,顺序是从右向左,SELECT column, group_function(column). . . FROM table WHERE condition GROUP BY ROLLUP group_by_expression HAVING having_expression; ORDER BY column;,ROLLUP 应用举例,1,2,3,CUBE 操作符,CUBE是对 GROUP BY 子句的扩展 CUBE 会产生类似于笛卡尔集的分组结果,SELECT column, group_function(column). FROM table WHERE condition GROUP BY CUBE group_by_expression HAVING having_expression ORDER BY column;,CUBE 应用举例,SELECT department_id, job_id, SUM(salary) FROM employees WHERE department_id 60 GROUP BY CUBE (department_id, job_id) ;,1,2,3,4,GROUPING 函数,GROUPING 函数可以和 CUBE 或 ROLLUP 结合使用 使用 GROUPING 函数,可以找到哪些列在该行中参加了分组 使用 GROUPING 函数, 可以区分空值产生的原因 GROUPING 函数返回 0 或 1,SELECT column, group_function(column) . , GROUPING(expr) FROM table WHERE condition GROUP BY ROLLUPCUBE group_by_expression HAVING having_expression ORDER BY column;,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);,2,1,3,GROUPING SETS,GROUPING SETS 是对GROUP BY 子句的进一步扩充 使用 GROUPING SETS 在同一个查询中定义多个分组集 Oracle 对 GROUPING SETS 子句指定的分组集进行分组后用 UNION ALL 操作将各分组结果结合起来 Grouping set 的优点: 只进行一次分组即可 不必书写复杂的 UNION 语句 GROUPING SETS 中包含的分组项越多,性能越好。,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,复合列,复合列是被作为整体处理的一组列的集合 ROLLUP (a, , d) 使用括号将若干列组成复合列在ROLLUP 或 CUBE 中作为整体进行操作 在ROLLUP 或 CUBE中, 复合列可以避免产生不必要的分组结果,(b,c),复合列应用举例,SELECT department_id, job_id, manager_id, SUM(salary) FROM employees GROUP BY ROLLUP( department_id,(job_id, manager_id);,2,1,3,连接分组集,连接分组集可以产生有用的对分组项的结合 将各分组集, ROLLUP 和 CUBE 用逗号连接 Oracle 自动在 GROUP BY 子句中将各分组集进行连接 连接的结果是对各分组生成笛卡尔集,GROUP BY GROUPING SETS(a, b), GROUPING SETS(c, d),连接分组集应用举例,SELECT department_id, job_id, manager_id, SUM(salary) FROM employees GROUP BY department_id, ROLLUP(job_id), CUBE(manager_id);,1,2,3,4,总结,通过本章学习,您已经可以: 使用 ROLLUP 操作符 使用 CUBE 操作符 使用 GROUPING 函数
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 合并慢性心力衰竭抗凝治疗的个体化ARNI个体化剂量方案
- 可穿戴设备在老年多病共存抗凝治疗中的监测策略
- 2025年光伏发电收益分配合同
- 变异株传播的消毒技术效果长期监测方案
- 2025广东阳江市阳西县选调公务员22人备考题库附答案
- 双向转诊机制中患者医联体分级诊疗参与策略
- 2026年一级建造师之一建铁路工程实务考试题库300道附完整答案【易错题】
- 2026年一级注册建筑师之建筑结构考试题库300道及完整答案一套
- 卵巢癌免疫微环境重塑与逆转策略
- 2025江西景德镇市总工会合同制工会社会工作者招聘15人备考题库附答案
- 广西投资引导基金有限责任公司招聘考试真题2024
- 三人合作协议合同书
- 2025云南昆明市惠筑建设开发有限公司招聘2人备考题库附答案详解(考试直接用)
- 健康体检中心护士年终总结(4篇)
- 2025山东菏泽市第三人民医院第二批招聘编制备案制人员3人笔试备考题库附答案解析
- 医院运营管理优化方案与成效
- 2025四川成都空港城市发展集团招聘35人笔试考试备考题库及答案解析
- 2025年幼儿园保健医考核试题及答案
- 2025化工行业环保法规变动与企业风险管理策略分析报告
- 铁总计统【2017】177号关于进一步加强铁路建设项目征地拆迁工作和费用管理的指导意见
- 保卫黄河曲谱
评论
0/150
提交评论