oracle数据库ppt+中科院培训专用Les17_cn.ppt_第1页
oracle数据库ppt+中科院培训专用Les17_cn.ppt_第2页
oracle数据库ppt+中科院培训专用Les17_cn.ppt_第3页
oracle数据库ppt+中科院培训专用Les17_cn.ppt_第4页
oracle数据库ppt+中科院培训专用Les17_cn.ppt_第5页
已阅读5页,还剩26页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、,增强 GROUP BY 子句,目标,完成本课后, 您应当能够: 用 ROLLUP 操作产生小计值 用 CUBE 操作产生交叉表值 用 GROUPING 函数确定由 ROLLUP 或 CUBE 创建的行值 用 GROUPING SETS 产生一个单个的结果集,组函数的回顾,组函数在行集上操作,给出分组结果,SELECTcolumn, group_function(column). . . FROMtable WHEREcondition GROUP BYgroup_by_expression ORDER BYcolumn;,SELECT AVG(salary), STDDEV(salary),

2、 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 ;,SELECTcolumn, FROMtable WHEREcondition GROUP BYgroup_by_expression ORDER BYcolumn;,例子:,语法:,grou

3、p_function(column). . .,HAVING 子句的回顾,用 HAVING 子句指定将被显示的那些组 在限制条件的基础上可以进一步约束分组,SELECTcolumn, group_function(column). FROMtable WHEREcondition GROUP BYgroup_by_expression HAVING having_expression ORDER BYcolumn;,带 ROLLUP 或 CUBE 运算的 GROUP BY,带 ROLLUP 或 CUBE 的 GROUP BY 子句用交叉引用列产生超合计行 ROLLUP 分组产生一个包含常规分组

4、行和小计值的结果集 CUBE 分组产生一个包含 ROLLUP 行和交叉表行的结果集,ROLLUP 操作,ROLLUP 是一个 GROUP BY 子句的扩展 用 ROLLUP 操作产生小计和累计,SELECTcolumn, group_function(column). . . FROMtable WHEREcondition GROUP BYROLLUP group_by_expression HAVING having_expression; ORDER BYcolumn;,ROLLUP 操作的例子,1,2,3,CUBE 操作,CUBE 是 GROUP BY 子句的扩展 能够用 CUBE 操

5、作产生带单个 SELECT 语句的交叉表值,SELECTcolumn, group_function(column). FROMtable WHEREcondition GROUP BYCUBE group_by_expression HAVING having_expression ORDER BYcolumn;,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,GR

6、OUPING 函数,GROUPING 函数既可以用于 CUBE 操作,也可以用于 ROLLUP 操作 用 GROUPING 函数模拟能够发现在一行中的构成小计的分组 用 GROUPING 函数,你能够从 ROLLUP 或 CUBE 创建的空值中区分存储的 NULL 值 GROUPING 函数返回 0 或 1,SELECT column, group_function(column), GROUPING(expr) FROM table WHERE condition GROUP BY ROLLUPCUBE group_by_expression HAVING having_expression

7、 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 是 GROUP BY 子句更进一步的扩展 你能够用 GROUPING SETS 在同一查询中定义多个分组

8、 Oracle 服务器计算在 GROUPING SETS 子句中指定的所有分组;用 UNION ALL 操作组合单个的分组结果 分组集合的效率: 对基表仅进行一次查询 不需要写复杂的 UNION 语句 GROUPING SETS 有更多的元素,更好的执行性能,Hidden Slide,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

9、,Hidden Slide,复合列,复合列是一个作为整体被处理的列集合 ROLLUP (a, , d) 为了指定复合列,用 GROUP BY 子句来分组在圆括号内的列,因此, Oracle 服务器在进行 ROLLUP 或 CUBE 操作时将它们作为一个整体来处理 当使用 ROLLUP 或 CUBE 时,复合列将跳过在确定级别上的聚合,(b,c),Hidden Slide,复合列: 例子,SELECT department_id, job_id, manager_id, SUM(salary) FROM employees GROUP BY ROLLUP( department_id,(job_

10、id, manager_id);,2,1,3,Hidden Slide,连接分组,连接分组提供一种简明的方式来生成有用的分组组合 为了指定连接分组集合,用逗号分开多重分组集合, 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 employeesGROUP BY department_id, ROLLUP(job_id), CUBE(manager_id);,1,2,3,4,小结,在本课中, 您应该已经学会如何: 用 ROLLUP 操作产生小计值 用 CUBE 操作产生交叉表值 用 GROUPING 函数指定由 ROLLUP 或 CUBE 创建的行值 用 GROUPING SETS 语法定义在同一查询中的多重分组 用 GROUP BY 子句以不同的方式组合表达式:

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论