版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、分组函数,目标,通过本章学习,您将可以: 了解组函数。 描述组函数的用途。 使用GROUP BY 子句对数据分组。 使用HAVING 字句过滤分组结果集。,什么是分组函数,分组函数作用于一组数据,并对一组数据返回一个值。,EMPLOYEES,表 EMPLOYEES 中的工资最大值,组函数类型,AVG COUNT MAX MIN STDDEV SUM,SELECTcolumn, group_function(column), . FROMtable WHEREcondition GROUP BYcolumn ORDER BYcolumn;,组函数语法,SELECT AVG(salary), MA
2、X(salary), MIN(salary), SUM(salary) FROM employees WHERE job_id LIKE %REP%;,AVG(平均值)和 SUM (合计)函数,可以对数值型数据使用AVG 和 SUM 函数。,MIN(最小值) 和 MAX(最大值)函数,可以对任意数据类型的数据使用 MIN 和 MAX 函数。,SELECT MIN(hire_date), MAX(hire_date) FROM employees;,SELECT COUNT(*) FROM employees WHERE department_id = 50;,COUNT(计数)函数,COUNT
3、(*) 返回表中记录总数。,COUNT(计数)函数,COUNT(expr) 返回 expr不为空的记录总数。,SELECT COUNT(commission_pct) FROM employees WHERE department_id = 80;,SELECT COUNT(DISTINCT department_id) FROM employees;,DISTINCT 关键字,COUNT(DISTINCT expr) 返回 expr非空且不重复的记录总数,SELECT AVG(commission_pct) FROM employees;,组函数与空值,组函数忽略空值。,SELECT AVG
4、(NVL(commission_pct, 0) FROM employees;,在组函数中使用NVL函数,NVL函数使分组函数无法忽略空值。,分组数据,EMPLOYEES,求出 EMPLOYEES表中各 部门的 平均工资,4400,9500,3500,6400,10033,SELECTcolumn, group_function(column) FROMtable WHEREcondition GROUP BYgroup_by_expression ORDER BYcolumn;,分组数据: GROUP BY 子句语法,可以使用GROUP BY 子句将表中的数据分成若干组,SELECT dep
5、artment_id, AVG(salary) FROM employees GROUP BY department_id ;,GROUP BY 子句,在SELECT 列表中所有未包含在组函数中的列都应包含在 GROUP BY 子句中。,GROUP BY 子句,包含在 GROUP BY 子句中的列不必包含在SELECT 列表中。,SELECT AVG(salary) FROM employees GROUP BY department_id ;,使用多个列分组,EMPLOYEES,使用多个列 进行分组,SELECT department_id dept_id, job_id, SUM(sala
6、ry) FROM employees GROUP BY department_id, job_id ;,在GROUP BY 子句中包含多个列,非法使用组函数,所用包含于SELECT 列表中,而未包含于组函数中的列都 必须包含于 GROUP BY 子句中。,SELECT department_id, COUNT(last_name) FROM employees;,SELECT department_id, COUNT(last_name) * ERROR at line 1: ORA-00937: not a single-group group function,GROUP BY 子句中缺少
7、列,非法使用组函数,不能在 WHERE 子句中使用组函数。 可以在HAVING 子句中使用组函数。,SELECT department_id, AVG(salary) FROM employees WHERE AVG(salary) 8000 GROUP BY department_id;,WHERE AVG(salary) 8000 * ERROR at line 3: ORA-00934: group function is not allowed here,WHERE 子句中不能使用组函数,过滤分组,The maximumsalaryper department when it is g
8、reater than$10,000,EMPLOYEES,SELECTcolumn, group_function FROMtable WHEREcondition GROUP BYgroup_by_expression HAVINGgroup_condition ORDER BYcolumn;,过滤分组: HAVING 子句,使用 HAVING 过滤分组: 1.行已经被分组。 2.使用了组函数。 3.满足HAVING 子句中条件的分组将被显示。,HAVING 子句,SELECT department_id, MAX(salary) FROM employees GROUP BY depart
9、ment_id HAVING MAX(salary)10000 ;,SELECT job_id, SUM(salary) PAYROLL FROM employees WHERE job_id NOT LIKE %REP% GROUP BY job_id HAVING SUM(salary) 13000 ORDER BY SUM(salary);,HAVING 子句,嵌套组函数,显示平均工资的最大值,SELECT MAX(AVG(salary) FROM employees GROUP BY department_id;,SELECTcolumn, group_function(column) FROMtable W
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 车辆抵押借款合同(汇编15篇)
- 车库人工挖孔桩专项施工方案
- 泌尿系统结石辩证
- 2025 高中语文必修上册《声声慢(寻寻觅觅)》李清照词中情感的细腻表达的节奏韵律课件
- 机车车辆制动试题及答案
- 血压计使用试题及答案
- 2025年临床执业医师《外科学》测试练习卷
- 医保基金使用自查规范考核试题及答案
- 医保内控管理制度培训试题及答案
- 2026东北三省三校高三下学期一模考试地理试卷和答案
- GB/T 9867-2008硫化橡胶或热塑性橡胶耐磨性能的测定(旋转辊筒式磨耗机法)
- GB/T 3195-2008铝及铝合金拉制圆线材
- 整形美容医院与公立整形医院合作方案
- 合理安排课余生活-完整版公开课件
- bbf-dhda双轴交流伺服驱动器说明书
- 《电视摄像教程》课件第6章
- 人大换届选举培训提纲汇编课件
- 2022青岛版科学五年级下册全册优质教案教学设计
- Unit10Lesson2Communityspirit课件-高中英语北师大版(2019)选择性必修第四册
- 建设项目全过程跟踪审计底稿(综合类、工程类、财务类)
- 2020 新ACLS-PCSA课前自我测试-翻译版玉二医【复制】附有答案
评论
0/150
提交评论