中科院西安分院oracle培训课件Les17章节

上传人:E**** 文档编号:91443444 上传时间:2019-06-28 格式:PPT 页数:20 大小:347.50KB
返回 下载 相关 举报
中科院西安分院oracle培训课件Les17章节_第1页
第1页 / 共20页
中科院西安分院oracle培训课件Les17章节_第2页
第2页 / 共20页
中科院西安分院oracle培训课件Les17章节_第3页
第3页 / 共20页
中科院西安分院oracle培训课件Les17章节_第4页
第4页 / 共20页
中科院西安分院oracle培训课件Les17章节_第5页
第5页 / 共20页
点击查看更多>>
资源描述

《中科院西安分院oracle培训课件Les17章节》由会员分享,可在线阅读,更多相关《中科院西安分院oracle培训课件Les17章节(20页珍藏版)》请在金锄头文库上搜索。

1、,增强 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(sal

2、ary), 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;,例子

3、:,语法:,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;,GROUP BY 带 ROLLUP 或 CUBE 操作,带 ROLLUP 或 CUBE 的 GROUP BY 子句用交叉引用列产生超合计行 ROLLU

4、P 分组产生一个包含常规分组行和小计值的结果集 CUBE 分组产生一个包含 ROLLUP 行和交叉表行的结果集,ROLLUP 操作,ROLLUP 是一个 GROUP BY 子句的扩展 用 ROLLUP 操作产生小计和累计,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

5、BY 子句的扩展 能够用 CUBE 操作产生带单个 SELECT 语句的交叉表值,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

6、_id, job_id) ;,1,2,3,4,GROUPING 函数,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_expre

7、ssion 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 是 GROUP BY 子句更进一步的扩展

8、 你能够用 GROUPING SETS 在同一查询中定义多重分组 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

9、,job_id), (job_id,manager_id);,1,2,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 GR

10、OUP BY ROLLUP( department_id,(job_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(sa

11、lary) FROM employees GROUP BY department_id, ROLLUP(job_id), CUBE(manager_id);,1,2,3,4,小结,在本课中, 您应该已经学会如何: 用 ROLLUP 操作产生小计值 用 CUBE 操作产生交叉表值 用 GROUPING 函数指定由 ROLLUP 或 CUBE 创建的行值 用 GROUPING SETS 语法定义在同一查询中的多重分组 用 GROUP BY 子句以不同的方式组合表达式: 组合列 连接分组集合,练习 17 概览,本章练习包括下面的主题: 使用 ROLLUP 操作 使用 CUBE 操作 使用 GROUPING 函数 使用 GROUPING SETS,Hidden Slide,Hidden Slide,Hidden Slide,Hidden Slide,Hidden Slide,Hidden Slide,

展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 高等教育 > 大学课件

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号