• 1. 对 GROUP BY 子句的扩展
  • 2. 目标通过本章学习,您将可以: 使用 ROLLUP 操作分组 使用 CUBE 操作分组 使用 GROUPING 函数处理 ROLLUP 或 CUBE操作所产生的空值 使用 GROUPING SETS 操作进行单独分组
  • 3. 组函数组函数处理多行返回一个行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%';例子:
  • 4. 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). . .
  • 5. HAVING 子句使用 HAVING 对组函数进行限制 对查询进行第二次限制SELECT [column,] group_function(column)... FROM table [WHERE condition] [GROUP BY group_by_expression] [HAVING having_expression] [ORDER BY column];
  • 6. 带有ROLLUP 和 CUBE 操作的GROUP BY 子句使用带有ROLLUP 和 CUBE 操作的GROUP BY 子句产生多种分组结果 ROLLUP 产生n + 1种分组结果 CUBE 产生2的n次方种分组结果
  • 7. 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];
  • 8. ROLLUP 应用举例SELECT department_id, job_id, SUM(salary) FROM employees WHERE department_id < 60 GROUP BY ROLLUP(department_id, job_id);123
  • 9. 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];
  • 10. CUBE 应用举例SELECT department_id, job_id, SUM(salary) FROM employees WHERE department_id < 60 GROUP BY CUBE (department_id, job_id) ;1234
  • 11. GROUPING 函数GROUPING 函数可以和 CUBE 或 ROLLUP 结合使用 使用 GROUPING 函数,可以找到哪些列在该行中参加了分组 使用 GROUPING 函数, 可以区分空值产生的原因 GROUPING 函数返回 0 或 1SELECT [column,] group_function(column) . , GROUPING(expr) FROM table [WHERE condition] [GROUP BY [ROLLUP][CUBE] group_by_expression] [HAVING having_expression] [ORDER BY column];
  • 12. 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);213
  • 13. GROUPING SETSGROUPING SETS 是对GROUP BY 子句的进一步扩充 使用 GROUPING SETS 在同一个查询中定义多个分组集 Oracle 对 GROUPING SETS 子句指定的分组集进行分组后用 UNION ALL 操作将各分组结果结合起来 Grouping set 的优点: 只进行一次分组即可 不必书写复杂的 UNION 语句 GROUPING SETS 中包含的分组项越多,性能越好。
  • 14. 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)); 12…
  • 15. 复合列复合列是被作为整体处理的一组列的集合 ROLLUP (a, , d) 使用括号将若干列组成复合列在ROLLUP 或 CUBE 中作为整体进行操作 在ROLLUP 或 CUBE中, 复合列可以避免产生不必要的分组结果(b,c)
  • 16. 复合列应用举例SELECT department_id, job_id, manager_id, SUM(salary) FROM employees GROUP BY ROLLUP( department_id,(job_id, manager_id));213…
  • 17. 连接分组集连接分组集可以产生有用的对分组项的结合 将各分组集, ROLLUP 和 CUBE 用逗号连接 Oracle 自动在 GROUP BY 子句中将各分组集进行连接 连接的结果是对各分组生成笛卡尔集GROUP BY GROUPING SETS(a, b), GROUPING SETS(c, d)
  • 18. ………连接分组集应用举例SELECT department_id, job_id, manager_id, SUM(salary) FROM employees GROUP BY department_id, ROLLUP(job_id), CUBE(manager_id);………1234
  • 19. 总结通过本章学习,您已经可以: 使用 ROLLUP 操作符 使用 CUBE 操作符 使用 GROUPING 函数处理在 ROLLUP 或 CUBE中产生的空值 使用 GROUPING SETS 创建分组集 在 GROUP BY 子句中组合分组: 复合列 连接分组集
  • 20. (本页无文本内容)
  • 21. Hidden Slide
  • 22. Hidden Slide
  • 23. Hidden Slide
  • 24. Hidden Slide
  • 25. Hidden Slide
  • 26. Hidden Slide
  • 27. (本页无文本内容)