已阅读5页,还剩22页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
,对GROUPBY子句的扩展,目标,通过本章学习,您将可以:使用ROLLUP操作分组使用CUBE操作分组使用GROUPING函数处理ROLLUP或CUBE操作所产生的空值使用GROUPINGSETS操作进行单独分组,组函数,组函数处理多行返回一个行,SELECTcolumn,group_function(column).FROMtableWHEREconditionGROUPBYgroup_by_expressionORDERBYcolumn;,SELECTAVG(salary),STDDEV(salary),COUNT(commission_pct),MAX(hire_date)FROMemployeesWHEREjob_idLIKESA%;,例子:,GROUPBY子句,SELECTdepartment_id,job_id,SUM(salary),COUNT(employee_id)FROMemployeesGROUPBYdepartment_id,job_id;,SELECTcolumn,FROMtableWHEREconditionGROUPBYgroup_by_expressionORDERBYcolumn;,例子:,语法:,group_function(column).,HAVING子句,使用HAVING对组函数进行限制对查询进行第二次限制,SELECTcolumn,group_function(column).FROMtableWHEREconditionGROUPBYgroup_by_expressionHAVINGhaving_expressionORDERBYcolumn;,带有ROLLUP和CUBE操作的GROUPBY子句,使用带有ROLLUP和CUBE操作的GROUPBY子句产生多种分组结果ROLLUP产生n+1种分组结果CUBE产生2的n次方种分组结果,ROLLUP操作符,ROLLUP是对GROUPBY子句的扩展ROLLUP产生n+1种分组结果,顺序是从右向左,SELECTcolumn,group_function(column).FROMtableWHEREconditionGROUPBYROLLUPgroup_by_expressionHAVINGhaving_expression;ORDERBYcolumn;,ROLLUP应用举例,1,2,3,CUBE操作符,CUBE是对GROUPBY子句的扩展CUBE会产生类似于笛卡尔集的分组结果,SELECTcolumn,group_function(column).FROMtableWHEREconditionGROUPBYCUBEgroup_by_expressionHAVINGhaving_expressionORDERBYcolumn;,CUBE应用举例,SELECTdepartment_id,job_id,SUM(salary)FROMemployeesWHEREdepartment_id60GROUPBYCUBE(department_id,job_id);,1,2,3,4,GROUPING函数,GROUPING函数可以和CUBE或ROLLUP结合使用使用GROUPING函数,可以找到哪些列在该行中参加了分组使用GROUPING函数,可以区分空值产生的原因GROUPING函数返回0或1,SELECTcolumn,group_function(column).,GROUPING(expr)FROMtableWHEREconditionGROUPBYROLLUPCUBEgroup_by_expressionHAVINGhaving_expressionORDERBYcolumn;,GROUPING函数举例,SELECTdepartment_idDEPTID,job_idJOB,SUM(salary),GROUPING(department_id)GRP_DEPT,GROUPING(job_id)GRP_JOBFROMemployeesWHEREdepartment_id50GROUPBYROLLUP(department_id,job_id);,2,1,3,GROUPINGSETS,GROUPINGSETS是对GROUPBY子句的进一步扩充使用GROUPINGSETS在同一个查询中定义多个分组集Oracle对GROUPINGSETS子句指定的分组集进行分组后用UNIONALL操作将各分组结果结合起来Groupingset的优点:只进行一次分组即可不必书写复杂的UNION语句GROUPINGSETS中包含的分组项越多,性能越好。,GROUPINGSETS应用举例,SELECTdepartment_id,job_id,manager_id,avg(salary)FROMemployeesGROUPBYGROUPINGSETS(department_id,job_id),(job_id,manager_id);,1,2,复合列,复合列是被作为整体处理的一组列的集合ROLLUP(a,d)使用括号将若干列组成复合列在ROLLUP或CUBE中作为整体进行操作在ROLLUP或CUBE中,复合列可以避免产生不必要的分组结果,(b,c),复合列应用举例,SELECTdepartment_id,job_id,manager_id,SUM(salary)FROMemployeesGROUPBYROLLUP(department_id,(job_id,manager_id);,2,1,3,连接分组集,连接分组集可以产生有用的对分组项的结合将各分组集,ROLLUP和CUBE用逗号连接Oracle自动在GROUPBY子句中将各分组集进行连接连接的结果是对各分组生成笛卡尔集,GROUPBYGROUPINGSETS(a,b),GROUPINGSETS(c,d),连接分组集应用举例,SELECTdepartment_id,job_id,manager_id,SUM(salary)FROMemployeesGROUPBYdepartment_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. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 企业社会责任及公益活动策划方案
- 四川省事业单位联考易考易错模拟试题(共500题)试卷后附参考答案
- 四川昭化区事业单位第6次选调易考易错模拟试题(共500题)试卷后附参考答案
- 四川宜宾市事业单位招考高校毕业生易考易错模拟试题(共500题)试卷后附参考答案
- 任务2 吹干头发教学设计-2025-2026学年小学劳动三年级下册湘教版《劳动实践指导手册》
- 仪表维修班组长质量管理方案
- 制度实施监督员培训教材
- 初中英语人教新目标 (Go for it) 版八年级上册Unit 5 Do you want to watch a game show综合与测试教学设计及反思
- 共青团佛山市委员会招考雇员易考易错模拟试题(共500题)试卷后附参考答案
- 佛山市三水区环境运输和城市管理局(交通运输板块)事业单位人员易考易错模拟试题(共500题)试卷后附参考答案
- 护士面试自我介绍【合集11篇】
- 钢结构厂房施工组织设计含土建
- 青少年普法知识竞赛试题及答案大全
- 11维修设备设施情况
- 中国红十字会总会卫生网络管理系统开发及系统集成项目技术方案
- 四年级上册美术课件-12给同学画漫画 |浙美版
- GB/T 7252-2001变压器油中溶解气体分析和判断导则
- GB/T 32201-2015气体流量计
- GB/T 1527-2017铜及铜合金拉制管
- GB 15193.1-2014食品安全国家标准食品安全性毒理学评价程序
- 分角线投照技术口腔颌面外科学
评论
0/150
提交评论