资源预览内容
第1页 / 共31页
第2页 / 共31页
第3页 / 共31页
第4页 / 共31页
第5页 / 共31页
第6页 / 共31页
第7页 / 共31页
第8页 / 共31页
第9页 / 共31页
第10页 / 共31页
亲,该文档总共31页,到这儿已超出免费预览范围,如果喜欢就下载吧!
资源描述
,增强 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 分组产生一个包含常规分组行和小计值的结果集 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 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_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_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 是 GROUP BY 子句更进一步的扩展 你能够用 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,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 GROUP 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(salary) 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,
收藏 下载该资源
网站客服QQ:2055934822
金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号