SQL语言基础in.ppt_第1页
SQL语言基础in.ppt_第2页
SQL语言基础in.ppt_第3页
SQL语言基础in.ppt_第4页
SQL语言基础in.ppt_第5页
已阅读5页,还剩255页未读 继续免费阅读

下载本文档

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

文档简介

亿阳信通股份有限公司,SQL基础ForInformix,关系数据模型,代表系统(1)Oracle(2)Sybase(3)DB2(4)SQLserver(5)VFP(6)Access(7)DBASE,数据库模式对象,术语:表存放用户数据的所在视图数据查看的特殊方式索引加快访问数据的方法,数据库模式对象,表(Table)是用于存放用户数据的数据库对象。有关每个表的信息存放在数据字典中,利用这些信息,用户可以维护表中的数据。数据库触发器(DatabaseTriggers)是存储在数据库中的程序,并当某一事件(如数据变化和用户登录)发生时运行。视图(View)允许用户看到一个或多个表的自定义组合,视图使用存放在数据库中的SQL查询。当需要使用视图时,执行定义该视图所需的SQL语句,就如同用户自己编写了这些定义语句一样。索引(Index)是表的小型化拷贝,表的索引项允许Oracle快速访问表中的数据。,数据库模式对象,同义词(Synonym)是数据库对象的别名。同义词即数据库对象的昵称,就像称呼一个名叫Margaret的人为Maggie一样。授权(Grants)为对象所有者将权限授出,允许其他用户处理这些对象的数据。数据类型(DataType)是用户打算存储其信息的格式结构。Informix的数据格式有Int/Float/Char/Varchar/bin等,(1)关系:整个二维表(2)关系名:表格名称(3)元组:行数据(记录)(4)属性:列数据(字段)(5)属性名:列名称(字段名)(6)主码:唯一确定元组的属性组(关键字)(7)域:属性的取值范围(8)分量:元组中的一个属性值(9)关系模式:关系名(属性),如:学生(学号,姓名,性别,系别,年龄,籍贯)(10)约束实体完整性约束参照完整性约束用户定义的完整性约束,概念,基本SQL语句,目标,完成本节课学习后,应当达到如下目标:能够指出SQL语句中SELECT语句的作用执行一个基本SELECT查询语句,Select语句的功能,选择,投影,Table1,Table2,Table1,Table1,连接,基本SELECT语句,SELECTDISTINCT*,columnalias,.FROMtable;,SELECT关键字标明取哪些列的数据.FROM关键字标明从哪些表中取数据.,SQL语句的书写,SQL语句不是大小写敏感的。建议关键字用大写,其他用小写。SQL语句可以分布在一行或者多行中。关键字不能进行缩写,也不能分布在两行。一般地,不同的子句写在不同的行为宜。经常用跳格键或者缩进来增强可读性。,选出所有的列,DEPTNODNAMELOC-10ACCOUNTINGNEWYORK20RESEARCHDALLAS30SALESCHICAGO40OPERATIONSBOSTON,SQLSELECT*2FROMdept;,选出特定的列,DEPTNOLOC-10NEWYORK20DALLAS30CHICAGO40BOSTON,SQLSELECTdeptno,loc2FROMdept;,数学表达式,可以用下述的数学符号,将日期或者数字数据组合起来形成数学表达式,符号+-*/,描述加减乘除,在SQL语句中运用数学表达式,SQLSELECTename,sal,sal+3002FROMemp;,ENAMESALSAL+300-KING50005300BLAKE28503150CLARK24502750JONES29753275MARTIN12501550ALLEN16001900.14rowsselected.,表达式优先级,乘和除操作的优先级高于加和减。相同优先级的操作符自左向右进行计算。圆括号“(”“)”,用来重新组合表达式的优先级,操作符顺序,SQLSELECTename,sal,12*sal+1002FROMemp;,ENAMESAL12*SAL+100-KING500060100BLAKE285034300CLARK245029500JONES297535800MARTIN125015100ALLEN160019300.14rowsselected.,使用圆括号,SQLSELECTename,sal,12*(sal+100)2FROMemp;,ENAMESAL12*(SAL+100)-KING500061200BLAKE285035400CLARK245030600JONES297536900MARTIN125016200.14rowsselected.,定义空值(null),空值是一个表达不可用、未分配、未知、或者不适用等意义的值。空值与零和空格的概念不同,应当严格区分。,ENAMEJOBSALCOMM-KINGPRESIDENT5000BLAKEMANAGER2850.TURNERSALESMAN15000.14rowsselected.,SQLSELECTename,job,sal,comm2FROMemp;,数学表达式中空值的处理,如果数学表达式中包含了一个空值,那么该数学表达式计算的结果为空值,SQLselectename,12*sal+comm2fromemp3WHEREename=KING;,ENAME12*SAL+COMM-KING,定义一个列别名,重新命名一个列的名字有时很有用。可以用AS关键字为列名取一个别名。别名中不能使用空格,使用列的别名,SQLSELECTenameASname,salsalary2FROMemp;,NAMESALARY-.,串接操作符,可以将一些列连接起来,也可以将一些列和一些字符串连接起来。串接操作符用两个竖杠(|)表示。可以用这种方法创建一个由字符串组成的结果列。,使用串接操作符,SQLSELECTename|jobASEmployees2FROMemp;,Employees-KINGPRESIDENTBLAKEMANAGERCLARKMANAGERJONESMANAGERMARTINSALESMANALLENSALESMAN.14rowsselected.,文字(literal)字符串,文字字符串是包含在一个Select语句中的字符串、数字、或者日期。文字字符串必须用单引号()括起来。对于返回的每一行,文字字符串都显示一次。在生成报表时非常有用。,使用文字字符串,Employee_Details-KINGisaPRESIDENTBLAKEisaMANAGERCLARKisaMANAGERJONESisaMANAGERMARTINisaSALESMAN.14rowsselected.,SQLSELECTename|isa|job2ASEmployee_Details3FROMemp;,重复行,查询语句执行的结果,缺省的显示方法是显示所有的行,包括重复的行。,SQLSELECTdeptno2FROMemp;,DEPTNO-10301020.14rowsselected.,消除掉重复行,在SELECT语句中用DISTINCT关键字来消除所有重复的行。,SQLSELECTDISTINCTdeptno2FROMemp;,DEPTNO-102030,对数据进行限定和排序,目标,结束本节课后,应当达到如下:在一个查询中限定查询出的行对查询出的行进行排序,用“选择”限定行,选择查询出的行,用where子句限定查询出的行.Where子句紧跟在From子句之后.,SELECTDISTINCT*|columnalias,.FROMtableWHEREcondition(s);,运用WHERE子句,SQLSELECTename,job,deptno2FROMemp3WHEREjob=CLERK;,ENAMEJOBDEPTNO-JAMESCLERK30SMITHCLERK20ADAMSCLERK20MILLERCLERK10,字符串和日期,字符串和日期值应当用单引号括起来.字符串值大小写敏感,日期值对于日期的格式敏感。缺省的日期值格式:MON-DD-YYYY.例如:09-23-2002.为2002年9月23日,SQLSELECTename,job,deptno2FROMemp3WHEREename=;,JAMES,比较操作符,操作符=,含义等于大于大于或等于小于小于或等于不等于,使用比较操作符,SQLSELECTename,sal,comm2FROMemp3WHEREsalSELECTename,sal2FROMemp3WHEREsalBETWEEN1000AND1500;,用BETEEN操作符来查询出在某一范围内的行.,使用IN操作符,用IN操作符来检验一个值是否在一个列表中.,SQLSELECTempno,ename,sal,mgr2FROMemp3WHEREmgrIN(7902,7566,7788);,EMPNOENAMESALMGR-7902FORD300075667369SMITH80079027788SCOTT300075667876ADAMS11007788,使用LIKE操作符,用LIKE进行某个字符串值的通配符匹配,来选出某些行.查询条件中既可以包含字符,也可以包含数字.%代表个或者多个字符._代表一个字符.,SQLSELECTename2FROMemp3WHEREenameLIKES%;,使用LIKE操作符,可以混合使用模式字符串.如果要匹配这个字符,可以用来表示.,SQLSELECTename2FROMemp3WHEREenameLIKE_A%;,ENAME-MARTINJAMESWARD,使用ISNULL操作符,用ISNULL操作符来检查有无空值,SQLSELECTename,mgr2FROMemp3WHEREmgrISNULL;,ENAMEMGR-KING,逻辑操作符,操作符ANDORNOT,含义两个条件都为TRUE,则返回TRUE两个条件中任何一个为TRUE,则返回TRUE如果条件为FALSE,返回TRUE,使用AND操作符,AND需要所有的条件都为TRUE.,SQLSELECTempno,ename,job,sal2FROMemp3WHEREsal=11004ANDjob=CLERK;,EMPNOENAMEJOBSAL-7876ADAMSCLERK11007934MILLERCLERK1300,使用OR操作符,OR操作符只需任意条件为TRUE即可,SQLSELECTempno,ename,job,sal2FROMemp3WHEREsal=11004ORjob=CLERK;,EMPNOENAMEJOBSAL-7839KINGPRESIDENT50007698BLAKEMANAGER28507782CLARKMANAGER24507566JONESMANAGER29757654MARTINSALESMAN1250.7900JAMESCLERK950.14rowsselected.,使用NOT操作符,SQLSELECTename,job2FROMemp3WHEREjobNOTIN(CLERK,MANAGER,ANALYST);,ENAMEJOB-KINGPRESIDENTMARTINSALESMANALLENSALESMANTURNERSALESMANWARDSALESMAN,优先级规则,用圆括号可以改变操作符的优先级次序。,顺序操作符1所有比较操作符2NOT3AND4OR,优先级规则,ENAMEJOBSAL-KINGPRESIDENT5000MARTINSALESMAN1250ALLENSALESMAN1600TURNERSALESMAN1500WARDSALESMAN1250,SQLSELECTename,job,sal2FROMemp3WHEREjob=SALESMAN4ORjob=PRESIDENT5ANDsal1500;,优先级规则,ENAMEJOBSAL-KINGPRESIDENT5000ALLENSALESMAN1600,用圆括号强制改变操作符优先级.,SQLSELECTename,job,sal2FROMemp3WHERE(job=SALESMAN4ORjob=PRESIDENT)5ANDsal1500;,ORDERBY子句,用ORDERBY子句进行行的排序ASC:升序,缺省DESC:降序ORDERBY子句跟在SELECT语句之后,SQLSELECTename,job,deptno,hiredate2FROMemp3ORDERBYhiredate;,ENAMEJOBDEPTNOHIREDATE-SMITHCLERK2017-DEC-80ALLENSALESMAN3020-FEB-81.14rowsselected.,采用降序排序,SQLSELECTename,job,deptno,hiredate2FROMemp3ORDERBYhiredateDESC;,ENAMEJOBDEPTNOHIREDATE-ADAMSCLERK2012-JAN-83SCOTTANALYST2009-DEC-82MILLERCLERK1023-JAN-82JAMESCLERK3003-DEC-81FORDANALYST2003-DEC-81KINGPRESIDENT1017-NOV-81MARTINSALESMAN3028-SEP-81.14rowsselected.,按照列的别名来进行排序,SQLSELECTempno,ename,sal*12annsal2FROMemp3ORDERBYannsal;,EMPNOENAMEANNSAL-7369SMITH96007900JAMES114007876ADAMS132007654MARTIN150007521WARD150007934MILLER156007844TURNER18000.14rowsselected.,按照多个列进行排序,ORDERBY后的列的顺序既排序的顺序.,不可以按照SELECT列中没有的列来进行排序,SQLSELECTename,deptno,sal2FROMemp3ORDERBYdeptno,salDESC;,ENAMEDEPTNOSAL-KING105000CLARK102450MILLER101300FORD203000.14rowsselected.,总结,SELECTDISTINCT*|columnalias,.FROMtableWHEREcondition(s)ORDERBYcolumn,expr,aliasASC|DESC;,处理单行的函数,目标,完成本节课后,应当达到如下的目标:描述在SQL语句中可能用到的各种函数。在SELECT语句中使用字符串、数字、日期的函数。描述转换函数的用法,SQL函数,函数,函数处理动作,两种类型的SQL函数,函数,单行函数,多行函数,单行函数,操作数据项接收参数并返回一个值在返回的每一行上进行处理每一行都有一个处理结果可能要修改数据类型可以进行嵌套,function_name(column|expression,arg1,arg2,.),单行函数,格式转换,字符,数字,日期,常规处理,单行函数,字符函数,字符函数,LOWERUPPERINITCAP,SUBSTRLENGTHLPADRPADTRIMREPLACECONCAT,大小写转换函数,字符操作函数,函数,结果,大小写转换,对字符串的大小写进行转换,LOWER(SQLCourse)UPPER(SQLCourse)INITCAP(SQLCourse),sqlcourseSQLCOURSESqlCourse,使用大小写转换函数,查出员工Blake的号码、名字、部门号,SQLSELECTempno,ename,deptno2FROMemp3WHEREename=blake;norowsselected,EMPNOENAMEDEPTNO-7698BLAKE30,SQLSELECTempno,ename,deptno2FROMemp3WHEREename=UPPER(blake);,SUBSTR(String,1,3)LENGTH(String)LPAD(sal,10,*)TRIM(SFROMSSMITH)REPLACE(eachday,each,eve)CONCAT(Very,Good),Str6*5000MITHevedayVeryGood,函数,结果,字符操作函数,操作字符串,使用字符操作函数,SQLSELECTename,CONCAT(ename,job),LENGTH(ename),23FROMemp4WHERE,SUBSTR(job,1,5)=SALES;,ENAMECONCAT(ENAME,JOB)LENGTH(ENAME)INSTR(ENAME,A)-MARTINMARTINSALESMAN6ALLENALLENSALESMAN5TURNERTURNERSALESMAN6WARDWARDSALESMAN4,数字函数,ROUND:对指定的值进行四舍五入小数ROUND(45.926,2)45.93TRUNC:对指定的值进行取整小数TRUNC(45.926,2)45.92MOD:返回除法计算后的余数MOD(1600,300)100,使用ROUND函数,SQLSELECTROUND(45.923,2),ROUND(45.923,0),2ROUND(45.923,-1)3FROMDUAL;,ROUND(45.923,2)ROUND(45.923,0)ROUND(45.923,-1)-45.924650,SQLSELECTTRUNC(45.923,2),TRUNC(45.923),2TRUNC(45.923,-1)3FROMDUAL;,TRUNC(45.923,2)TRUNC(45.923)TRUNC(45.923,-1)-45.924540,使用TRUNC函数,使用MOD函数,计算工作为salesman的员工的工资(Sal),除以COMM后的余数。,SQLSELECTename,sal,comm,MOD(sal,comm)2FROMemp3WHEREjob=SALESMAN;,ENAMESALCOMMMOD(SAL,COMM)-MARTIN125014001250ALLEN1600300100TURNER150001500WARD1250500250,使用日期,两种日期类型date和datetimedate缺省的格式:MON-DD-YYYY.例如:12-25-2007CURRENT是一个返回日期和时间的函数.,常用日期函数,获取系统当前时间,CURRENT,INTERVAL,DAY/MONTH/YEAR/WEEKDAY,DATETIME,DATE,日期加减函数,调整date或datetime值的精度,返回表达式的日期时间值,返回表达式的日期值,函数,描述,返回表达式中得天/月/年/周,EXTEND,CURRENT(),使用Date函数,DAY(10-16-2008)orDAY(2008-10-1610:00:00),MONTH(10-16-2008)orMONTH(2008-10-1610:00:00),2008-10-1610:00:28,16,10,YEAR(10-16-2008)orYEAR(2008-10-1610:00:00),2008,WEEKDAY(10-16-2008)orWEEKDAY(2008-10-1610:00:00),4,使用日期函数,NVL函数,NVL(expr1,expr2)如果expr1为null,则返回expr2,否则返回expr1可以使用的数据类型是数字、日期、字符型.数据类型必须能够匹配NVL(comm,0)NVL(hiredate,01-JAN-97)NVL(job,NoJobYet),SQLSELECTename,sal,comm,(sal*12)+NVL(comm,0)2FROMemp;,使用NVL函数,ENAMESALCOMM(SAL*12)+NVL(COMM,0)-KING500060000BLAKE285034200CLARK245029400JONES297535700MARTIN1250140016400ALLEN160030019500.14rowsselected.,DECODE函数,DECODE函数的作用类似于CASEorIF-THEN-ELSE语句,DECODE(col/expression,search1,result1,search2,result2,.,default),使用DECODE函数,SQLSELECTjob,sal,2DECODE(job,ANALYST,SAL*1.1,3CLERK,SAL*1.15,4MANAGER,SAL*1.20,5SAL)6REVISED_SALARY7FROMemp;,JOBSALREVISED_SALARY-PRESIDENT50005000MANAGER28503420MANAGER24502940.14rowsselected.,使用DECODE函数,SQLSELECTename,sal,2DECODE(TRUNC(sal/1000,0),30,0.00,41,0.09,52,0.20,63,0.30,74,0.40,85,0.42,96,0.44,100.45)TAX_RATE11FROMemp12WHEREdeptno=30;,显示30号部门所有员工应交的税金.,函数的嵌套,单行的函数可以嵌套到任何一个层次.嵌套函数的计算顺序先计算深层嵌套,再计算浅层嵌套.,F3(F2(F1(col,arg1),arg2),arg3),Step1=Result1,Step2=Result2,Step3=Result3,嵌套函数,SQLSELECTename,2ABS(NVL(age,0)3FROMemp4WHEREmgrISNULL;,ENAME-KING0,总结,可以用函数来作如下的工作:对数据进行计算更改单个的数据条目操纵数据行的输出改变日期值的输出改变列的数据类型,作业概览,建立需要用到日期、数字、字符串的函数的查询。使用函数的串接和嵌套使用字符串函数,建立大小写敏感的查询。进行年、月等日期的计算。,从多个表中获取数据,目标,完成本节课的学习后,应当达到如下目标:写出能从多个等连接或者非等连接的表中取出数据的SQL语句。使用外连接来查找数据。写出一个表与其自身连接的SQL语句。,EMPNODEPTNOLOC-783910NEWYORK769830CHICAGO778210NEWYORK756620DALLAS765430CHICAGO749930CHICAGO.14rowsselected.,从多个表中获取数据,EMP,DEPT,EMPNOENAME.DEPTNO-.-7839KING.107698BLAKE.30.7934MILLER.10,DEPTNODNAMELOC-10ACCOUNTINGNEWYORK20RESEARCHDALLAS30SALESCHICAGO40OPERATIONSBOSTON,什么是连接?,用一个连接来从多个表中获取数据.在Where子句中书写连接的条件.如果某个列的名字在多个表中出现了,那么需要在列的名字前面加上表名作为前缀.,SELECTtable1.column,table2.columnFROMtable1,table2WHEREtable1.column1=table2.column2;,笛卡尔积,以笛卡尔积连接的表具有下列特征:连接条件被忽略。第一个表中的所有的行与第二个表中的所有行相连接。如果在WHERE子句中加入条件,那么可以避免笛卡尔积.,产生一个笛卡尔积,ENAMEDNAME-KINGACCOUNTINGBLAKEACCOUNTING.KINGRESEARCHBLAKERESEARCH.56rowsselected.,EMP(14行),DEPT(4行),EMPNOENAME.DEPTNO-.-7839KING.107698BLAKE.30.7934MILLER.10,DEPTNODNAMELOC-10ACCOUNTINGNEWYORK20RESEARCHDALLAS30SALESCHICAGO40OPERATIONSBOSTON,连接的类型,等连接,非等连接,外连接,自连接,什么是等连接?,EMP,DEPT,EMPNOENAMEDEPTNO-7839KING107698BLAKE307782CLARK107566JONES207654MARTIN307499ALLEN307844TURNER307900JAMES307521WARD307902FORD207369SMITH20.14rowsselected.,DEPTNODNAMELOC-10ACCOUNTINGNEWYORK30SALESCHICAGO10ACCOUNTINGNEWYORK20RESEARCHDALLAS30SALESCHICAGO30SALESCHICAGO30SALESCHICAGO30SALESCHICAGO30SALESCHICAGO20RESEARCHDALLAS20RESEARCHDALLAS.14rowsselected.,用等连接获取纪录,SQLSELECTemp.empno,emp.ename,emp.deptno,2dept.deptno,dept.loc3FROMemp,dept4WHEREemp.deptno=dept.deptno;,EMPNOENAMEDEPTNODEPTNOLOC-7839KING1010NEWYORK7698BLAKE3030CHICAGO7782CLARK1010NEWYORK7566JONES2020DALLAS.14rowsselected.,限定不明确的列名,用表名作为前缀来限定在多个表中都出现的列名字.利用表的前缀可以提高性能.使用不同的别名来标志在不同表中的相同的名字。,用AND操作符增加查询条件,EMP,DEPT,EMPNOENAMEDEPTNO-7839KING107698BLAKE307782CLARK107566JONES207654MARTIN307499ALLEN307844TURNER307900JAMES307521WARD307902FORD207369SMITH20.14rowsselected.,DEPTNODNAMELOC-10ACCOUNTINGNEWYORK30SALESCHICAGO10ACCOUNTINGNEWYORK20RESEARCHDALLAS30SALESCHICAGO30SALESCHICAGO30SALESCHICAGO30SALESCHICAGO30SALESCHICAGO20RESEARCHDALLAS20RESEARCHDALLAS.14rowsselected.,使用表的别名,使用的表的别名来简化查询,SQLSELECTemp.empno,emp.ename,emp.deptno,2dept.deptno,dept.loc3FROMemp,dept4WHEREemp.deptno=dept.deptno;,SQLSELECTe.empno,e.ename,e.deptno,2d.deptno,d.loc3FROMempe,deptd4WHEREe.deptno=d.deptno;,连接多个表,NAMECUSTID-JOCKSPORTS100TKBSPORTSHOP101VOLLYRITE102JUSTTENNIS103K+TSPORTS105SHAPEUP106WOMENSSPORTS107.9rowsselected.,CUSTOMER,非等连接,EMP,SALGRADE,EMPNOENAMESAL-7839KING50007698BLAKE28507782CLARK24507566JONES29757654MARTIN12507499ALLEN16007844TURNER15007900JAMES950.14rowsselected.,GRADELOSALHISAL-17001200212011400314012000420013000530019999,用非等连接查询记录,ENAMESALGRADE-JAMES9501SMITH8001ADAMS11001.14rowsselected.,SQLSELECTe.ename,e.sal,s.grade2FROMempe,salgrades3WHEREe.sal4BETWEENs.losalANDs.hisal;,外连接,EMP,DEPT,ENAMEDEPTNO-KING10BLAKE30CLARK10JONES20.,DEPTNODNAME-10ACCOUNTING30SALES10ACCOUNTING20RESEARCH.40OPERATIONS,外连接,可以用外连接来查出在一个表中,不匹配连接条件的行.外连接的关键字是:outer,SELECTtable1.column,table2.columnFROMtable1,outertable2WHEREtable1.column=table2.column;,使用外连接,SQLSELECTe.ename,d.deptno,d.dname2FROMdeptd,outerempe3WHEREe.deptno=d.deptno4ORDERBYe.deptno;,ENAMEDEPTNODNAME-KING10ACCOUNTINGCLARK10ACCOUNTING.40OPERATIONS15rowsselected.,自连接,EMP(WORKER),EMP(MANAGER),EMPNOENAMEMGR-7839KING7698BLAKE78397782CLARK78397566JONES78397654MARTIN76987499ALLEN7698,EMPNOENAME-7839KING7839KING7839KING7698BLAKE7698BLAKE,表与自身连接,WORKER.ENAME|WORKSFOR|MANAG-BLAKEworksforKINGCLARKworksforKINGJONESworksforKINGMARTINworksforBLAKE.13rowsselected.,SQLSELECTworker.ename|worksfor|manager.ename2FROMempworker,empmanager3WHEREworker.mgr=manager.empno;,总结,等连接,非等连接,外连接,自连接,SELECTtable1.column,table2.columnFROMtable1,table2WHEREtable1.column1=table2.column2;,作业概览,用等连接来连接不同的表练习使用外连接和自连接增加连接的条件,使用分组函数来对数据进行聚集,目标,完成本节课的学习后,应当完成下面的目标:识记常用的分组函数。描述分组函数的用处。使用GROUPBY子句对元组进行分组使用HAVING子句来筛选分组,什么是分组函数?,分组函数对一组数据行进行操作,并对每个组得出一个结果.,EMP,“EMP表中最大的SAL值”,DEPTNOSAL-1024501050001013002080020110020300020300020297530160030285030125030950301500301250,MAX(SAL)-5000,分组函数的类型,AVGCOUNTMAXMINSUM,使用分组函数,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;,将表中的数据行用GROUPBY语句分为几个组.,使用GROUPBY子句,在SELECT语句中,没有使用分组函数的列必须在GROUPBY子句中.,SQLSELECTdeptno,AVG(sal)2FROMemp3GROUPBYdeptno;,DEPTNOAVG(SAL)-102916.6667202175301566.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,分组函

温馨提示

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

评论

0/150

提交评论