oracle数据库sql语句聚集(分组)函数.ppt_第1页
oracle数据库sql语句聚集(分组)函数.ppt_第2页
oracle数据库sql语句聚集(分组)函数.ppt_第3页
oracle数据库sql语句聚集(分组)函数.ppt_第4页
oracle数据库sql语句聚集(分组)函数.ppt_第5页
已阅读5页,还剩20页未读 继续免费阅读

下载本文档

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

文档简介

五、聚集(分组)函数,目标,完成本节课的学习后,应当完成下面的目标:识记常用的分组函数。描述分组函数的用处。使用GROUPBY子句对元组进行分组使用HAVING子句来筛选分组,什么是分组函数?,分组函数对一组数据行进行操作,并对每个组得出一个结果.,EMP,“EMP表中最大的SAL值”,DEPTNOSAL-1024501050001013002080020110020300020300020297530160030285030125030950301500301250,MAX(SAL)-5000,分组函数的类型,AVGCOUNTMAXMINSTDDEVSUMVARIANCE,使用分组函数,SELECTcolumn,group_function(column)FROMtableWHEREconditionGROUPBYcolumnORDERBYcolumn;,使用AVG和SUM函数,AVG(SAL)MAX(SAL)MIN(SAL)SUM(SAL)-1400160012505600,对于数字类型的数据,可以使用AVG和SUM函数.,SQLSELECTAVG(sal),MAX(sal),2MIN(sal),SUM(sal)3FROMemp4WHEREjobLIKESALES%;,使用MIN和MAX函数,可以对许多类型的数据使用MIN和MAX函数.,SQLSELECTMIN(hiredate),MAX(hiredate)2FROMemp;,MIN(HIREDMAX(HIRED-17-DEC-8012-JAN-83,使用COUNT函数,COUNT(*)-6,SQLSELECTCOUNT(*)2FROMemp3WHEREdeptno=30;,COUNT(*)返回查询出的总行数.,使用COUNT函数,COUNT(expr)返回expr值非空的行的数.,SQLSELECTCOUNT(comm)2FROMemp3WHEREdeptno=30;,COUNT(COMM)-4,分组函数和空值,分组函数忽略了行中所有的空行.,SQLSELECTAVG(comm)2FROMemp;,AVG(COMM)-550,分组函数和NVL函数的结合,NVL函数使得分组函数可以处理空值.,SQLSELECTAVG(NVL(comm,0)2FROMemp;,AVG(NVL(COMM,0)-157.14286,创建聚组数据,EMP,“EMP表中每个部门的平均工资”,2916.6667,2175,1566.6667,DEPTNOSAL-1024501050001013002080020110020300020300020297530160030285030125030950301500301250,DEPTNOAVG(SAL)-102916.6667202175301566.6667,GROUPBY子句,SELECTcolumn,group_function(column)FROMtableWHEREconditionGROUPBYgroup_by_expressionORDERBYcolumn;,将表中的数据行用GROUP语句分为几个组.,使用GROUPBY子句,在SELECT语句中,没有使用分组函数的列必须在GROUPBy子句中.,SQLSELECTdeptno,AVG(sal)2FROMemp3GROUPBYdeptno;,DEPTNOAVG(SAL)-102916.6667202175301566.6667,使用GROUPBY子句,GROUPBY后面的列可以不出现在SELECT链中.,SQLSELECTAVG(sal)2FROMemp3GROUPBYdeptno;,AVG(SAL)-2916.666721751566.6667,根据多个列进行分组,EMP,“每个部门中,每种工作的工资总和”,DEPTNOJOBSAL-10MANAGER245010PRESIDENT500010CLERK130020CLERK80020CLERK110020ANALYST300020ANALYST300020MANAGER297530SALESMAN160030MANAGER285030SALESMAN125030CLERK95030SALESMAN150030SALESMAN1250,JOBSUM(SAL)-CLERK1300MANAGER2450PRESIDENT5000ANALYST6000CLERK1900MANAGER2975CLERK950MANAGER2850SALESMAN5600,DEPTNO-101010202020303030,在多个列上使用GROUPBY子句,SQLSELECTdeptno,job,sum(sal)2FROMemp3GROUPBYdeptno,job;,DEPTNOJOBSUM(SAL)-10CLERK130010MANAGER245010PRESIDENT500020ANALYST600020CLERK1900.9rowsselected.,分组函数的误用,在SELECT语句中,任何不在聚组函数中出现的列,必须在GROUPBY子句中.,SQLSELECTdeptno,COUNT(ename)2FROMemp;,SELECTdeptno,COUNT(ename)*ERRORatline1:ORA-00937:notasingle-groupgroupfunction,Deptno列没有在GROUPBY子句中出现,分组函数的误用,不能在WHERE子句中对列做出限定.使用HAVING子句来限定分组.,SQLSELECTdeptno,AVG(sal)2FROMemp3WHEREAVG(sal)20004GROUPBYdeptno;,WHEREAVG(sal)2000*ERRORatline3:ORA-00934:groupfunctionisnotallowedhere,不能用WHERE子句对分组做出限定,排除聚组结果,每组中薪水大于$2900的员工号”,EMP,DEPTNOSAL-1024501050001013002080020110020300020300020297530160030285030125030950301500301250,DEPTNOMAX(SAL)-105000203000,用HAVING子句排除分组结果,用HAVING子句来限定分组行被分组了.使用了分组函数.符合HAVING子句条件的组将被显示出来.,SELECTcolumn,group_functionFROMtableWHEREconditionGROUPBYgroup_by_expressionHAVINGgroup_conditionORDERBYcolumn;,使用HAVING子句,SQLSELECTdeptno,max(sal)2FROMemp3GROUPBYdeptno4HAVINGmax(sal)2900;,DEPTNOMAX(SAL)-105000203000,使用HAVING子句,SQLSELECTjob,SUM(sal)PAYROLL2FROMemp3WHEREjobNOTLIKESALES%4GROUPBYjob6ORDERBYSUM(sal);,JOBPAYROLL-ANALYST6000MANAGER8275,5HAVINGSUM(sal)5000,分组函数的嵌套使用,SQLSELECTmax(avg(sal)2FROMemp3GROUPBYdeptno;,MAX(AVG(SAL)-2916.6667,显示最大的平均工

温馨提示

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

最新文档

评论

0/150

提交评论