欢迎来到三一办公! | 帮助中心 三一办公31ppt.com(应用文档模板下载平台)
三一办公
全部分类
  • 办公文档>
  • PPT模板>
  • 建筑/施工/环境>
  • 毕业设计>
  • 工程图纸>
  • 教育教学>
  • 素材源码>
  • 生活休闲>
  • 临时分类>
  • ImageVerifierCode 换一换
    首页 三一办公 > 资源分类 > PPT文档下载  

    SQL数据库基础培训.ppt

    • 资源ID:5449421       资源大小:1.27MB        全文页数:205页
    • 资源格式: PPT        下载积分:15金币
    快捷下载 游客一键下载
    会员登录下载
    三方登录下载: 微信开放平台登录 QQ登录  
    下载资源需要15金币
    邮箱/手机:
    温馨提示:
    用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)
    支付方式: 支付宝    微信支付   
    验证码:   换一换

    加入VIP免费专享
     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

    SQL数据库基础培训.ppt

    第1章 安装,1.1 ORACLE数据库安装1.2 PL/SQL工具安装,默认下一步即可.1.3 配置本机tnsname.ora文件1.4 测试tnsname.ora配置是否正确1.5 PL/SQL登录,第2章 SQL基础,2.1 数据库查询语言SQL2.2 基本查询和排序2.3 条件查询 2.4 函数 2.5 高级查询2.6 阶段训练2.7 练习,2.1 数据库查询语言SQL,2.1.1 SQL语言的特点和分类SQL语言有以下的主要特点:*SQL语言可以在Oracle数据库中创建、存储、更新、检索和维护数据,其中主要的功能是实现数据的查询和数据的插入、删除、修改等操作。*SQL语言在书写上类似于英文,简洁清晰,易于理解。它由关键字、表名、字段名,表达式等部分构成。,*SQL语言属于非过程化的4GL(第四代语言)。*SQL语言按功能可分为DDL语言、DML语言、DCL语言和数据库事务处理语言四个类别。*SQL语言的主要关键字有:ALTER、DROP、REVOKE、AUDIT、GRANT、ROLLBACK、COMMIT、INSERT、SELECT、COMMENT、LOCK、UPDATE、CREATE、NOAUDIT、VALIDATE、DELETE、RENAME等。按照SQL语言的不同功用,可以进一步对SQL语言进行划分。下表给出了SQL语言的分类和功能简介。,表2-1 SQL语言的分类,2.1.2 SQL的基本语法SQL语言的语法比较简单,类似于书写英文的语句。其语句一般由主句和若干个从句组成,主句和从句都由关键字引导。主句表示该语句的主要功能,从句表示一些条件或限定,有些从句是可以省略的。在语句中会引用到列名、表名或表达式。另外还有如下一些说明:*关键字、字段名、表名等之间都要用空格或逗号等进行必要的分隔。*语句的大小写不敏感(查询的内容除外)。*语句可以写在一行或多行。*语句中的关键字不能略写和分开写在两行。,*要在每条SQL语句的结束处添加“;”号。*为了提高可读性,可以使用缩进。*从句一般写在另一行的开始处。查询语句是最常见的SQL语句,它从给定的表中,把满足条件的内容检索出来。以下是最基本的SELECT语句语法。SELECT 字段名列表 FROM 表名 WHERE 条件;SELECT为查询语句的关键字,后跟要查询的字段名列表,字段名列表用来指定检索特定的字段,该关键字不能省略。,字段名列表代表要查询的字段。FROM 也是查询语句关键字,后面跟要查询的表名,该关键字不能省略。WHERE条件限定检索特定的记录,满足“条件”的记录被显示出来,不满足条件的被过滤掉。语句查询的结果往往是表的一部分行和列。如果字段名列表使用*,将检索全部的字段。如果省略WHERE条件,将检索全部的记录。,【训练1】查询部门10的雇员。输入并执行查询:SELECT*FROM emp WHERE deptno=10;结果略。说明:该查询语句从emp表中检索出部门10 的雇员,条件由WHERE deptno=10 子句指定。,2.2 基本查询和排序,2.2.1 查询的基本用法在Oracle数据库中,对象是属于模式的,每个账户对应一个模式,模式的名称就是账户名称。在表名前面要添加模式的名字,在表的模式名和表名之间用“.”分隔。我们以不同的账户登录数据库时,就进入了不同的模式,比如登录到STUDENT 账户,就进入了STUDENT模式。而在STUDENT模式要查询属于SCOTT模式的表,就需要写成:SELECT*FROM SCOTT.EMP;,但如果登录用户访问属于用户模式本身的表,那么可以省略表名前面的模式名称。SELECT*FROM emp;1指定检索字段下面的练习,只显示表的指定字段。【训练1】显示DEPT表的指定字段的查询。输入并执行查询:SELECT deptno,dname FROM dept;,显示结果如下:DEPTNO DNAME-10 ACCOUNTING 20 RESEARCH 30 SALES 40 OPERATIONS说明:结果只包含2列deptno和dname。在语句中给出要显示的列名,列名之间用“,”分隔。表头的显示默认为全部大写。对于日期和数值型数据,右对齐显示,如deptno列。对于字符型数据,左对齐显示,如dname列。,【练习1】显示emp表的雇员名称和工资。2显示行号每个表都有一个虚列ROWNUM,它用来显示结果中记录的行号。我们在查询中也可以显示这个列。【训练2】显示EMP表的行号。输入并执行查询:SELECT rownum,ename FROM emp;,结果如下:ROWNUM ENAME-1 SMITH 2 ALLEN 3 WARD 4 JONES 注意:显示的行号是查询结果的行号,数据在数据库中是没有行号的。,3显示计算列在查询语句中可以有算术表达式,它将形成一个新列,用于显示计算的结果,通常称为计算列。表达式中可以包含列名、算术运算符和括号。括号用来改变运算的优先次序。常用的算术运算符包括:*+:加法运算符。*-:减法运算符。*:乘法运算符。*/:除法运算符。以下训练在查询中使用了计算列。,【训练3】显示雇员工资上浮20%的结果。输入并执行查询:SELECT ename,sal,sal*(1+20/100)FROM emp;显示结果为:ENAME SAL SAL*(1+20/100)-SMITH 800 960ALLEN 1600 1920说明:结果中共显示了3列,第3列显示工资上浮20%的结果,它不是表中存在的列,而是计算产生的结果,称为计算列。,【练习2】显示EMP表的雇员名称以及工资和津贴的和。4使用别名我们可以为表的列起一个别名,它的好处是,可以改变表头的显示。特别是对于计算列,可以为它起一个简单的列别名以代替计算表达式在表头的显示。【训练4】在查询中使用列别名。输入并执行:SELECT ename AS 名称,sal 工资 FROM emp;显示结果为:名称 工资-SMITH 800ALLEN 1600,说明:表头显示的是列别名,转换为汉字显示。在列名和别名之间要用AS分隔,如ename和它的别名“名称”之间用AS隔开。AS也可以省略,如sal和它的别名“工资”之间用空格分割。注意:如果用空格分割,要区别好列名和别名,前面为列名,后面是别名。别名如果含有空格或特殊字符或大小写敏感,需要使用双引号将它引起来。,【训练5】在列别名上使用双引号。输入并执行查询:SELECT ename AS Name,sal*12+5000 AS 年度工资(加年终奖)FROM emp;显示结果为:Name 年度工资(加年终奖)-SMITH 14600ALLEN 24200,说明:其中别名“Name”有大小写的区别,别名“年度工资(加年终奖)”中出现括号,属于特殊符号,所以都需要使用双引号将别名引起。【练习3】显示DEPT表的内容,使用别名将表头转换成中文显示。5连接运算符在前面,我们使用到了包含数值运算的计算列,显示结果也是数值型的。我们也可以使用字符型的计算列,方法是在查询中使用连接运算。连接运算符是双竖线“|”。通过连接运算可以将两个字符串连接在一起。,【训练6】在查询中使用连接运算。输入并执行查询:SELECTename|job AS 雇员和职务表 FROM emp;输出结果为:雇员和职务表-SMITHCLERKALLENSALESMAN,说明:在本例中,雇员名称和职务列被连接成为一个列显示。在查询中可以使用字符和日期的常量,表示固定的字符串或固定日期。字符和日期的常量需要用单引号引起。下一个训练是作为上一个训练的改进。,【训练7】在查询中使用字符串常量。输入并执行查询:SELECTename|IS|job AS 雇员和职务表 FROM emp;输出结果为:雇员和职务表-SMITH IS CLERKALLEN IS SALESMAN说明:本练习中将雇员名称、字符串常量“IS”和雇员职务3个部分连接在一起。,【练习4】显示DEPT表的内容,按以下的形式:部门ACCOUNTING所在的城市为NEW YORK 6消除重复行如果在显示结果中存在重复行,可以使用的关键字DISTINCT消除重复显示。,【训练8】使用DISTINCT消除重复行显示。输入并执行查询:SELECT DISTINCT job FROM emp;结果为:JOB-ANALYSTCLERKMANAGERPRESIDENTSALESMAN,说明:在本例中,如果不使用DISTINCT关键字,将重复显示雇员职务,DISTINCT关键字要紧跟在SELECT之后。请去掉DISTINCT关键字,重新执行,并观察显示结果的不同。【练习5】显示EMP表中不同的部门编号。2.2.2 查询结果的排序如果要在查询的同时排序显示结果,可以使用如下的语句:SELECT 字段列表 FROM 表名 WHERE 条件ORDER BY 字段名1 ASC|DESC,字段名2 ASC|DESC.;,ORDER BY从句后跟要排序的列。ORDER BY 从句出现在SELECT语句的最后。排序有升序和降序之分,ASC表示升序排序,DESC表示降序排序。如果不指明排序顺序,默认的排序顺序为升序。如果要降序,必须书写DESC关键字。,1升序排序【训练1】查询雇员姓名和工资,并按工资从小到大排序。输入并执行查询:SELECT ename,sal FROM emp ORDER BY sal;执行结果为:ENAME SAL-SMITH 800JAMES 950注意:若省略ASC和DESC,则默认为ASC,即升序排序。,2降序排序【训练2】查询雇员姓名和雇佣日期,并按雇佣日期排序,后雇佣的先显示。输入并执行查询:SELECT ename,hiredate FROM emp ORDER BY hiredate DESC;结果如下:ENAME HIREDATE-ADAMS 23-5月-87SCOTT 19-4月-87,MILLER 23-1月-82JAMES 03-12月-81FORD 03-12月-81注意:DESC表示降序排序,不能省略。3多列排序可以按多列进行排序,先按第一列,然后按第二列、第三列.。【训练3】查询雇员信息,先按部门从小到大排序,再按雇佣时间的先后排序。输入并执行查询:SELECT ename,deptno,hiredate FROM emp ORDER BY deptno,hiredate;,结果如下:ENAME DEPTNO HIREDATE-CLARK 10 09-6月-81KING 10 17-11月-81MILLER 10 23-1月-82SMITH 20 17-12月-80JONES 20 02-4月-81FORD 20 03-12月-81SCOTT 20 19-4月-87说明:该排序是先按部门升序排序,部门相同的情况下,再按雇佣时间升序排序。,4在排序中使用别名如果要对计算列排序,可以为计算列指定别名,然后按别名排序。【训练4】按工资和工作月份的乘积排序。输入并执行查询:SELECT empno,ename,sal*Months_between(sysdate,hiredate)AS total FROM emp ORDER BY total;,执行结果为:EMPNO ENAME TOTAL-7876ADAMS 221526.006 7369 SMITH 222864.661 7900 JAMES 253680.817 7654 MARTIN 336532.484说明:求得雇员工作月份的函数Months_between将在后面介绍。sysdate表示当前日期。【练习1】将部门表中的部门名称按字母顺序显示。,2.3 条件查询,2.3.1 简单条件查询要对显示的行进行限定,可在FROM从句后使用WHERE从句,在WHERE从句中给出限定的条件,因为限定条件是一个表达式,所以称为条件表达式。条件表达式中可以包含比较运算,表达式的值为真的记录将被显示。常用的比较运算符列于表2-2中。,表2-2 比 较 运 算 符,【训练1】显示职务为“SALESMAN”的雇员的姓名、职务和工资。输入并执行查询:SELECT ename,job,sal FROM emp WHERE job=SALESMAN;执行结果为:ENAME JOB SAL-ALLEN SALESMAN 1600WARD SALESMAN 1250MARTIN SALESMAN 1250TURNER SALESMAN 1500,说明:结果只显示职务为“SALESMAN”的雇员。字符串和日期型数据的值是包含在单引号中的,如SALESMAN,需要用单引号引起。字符的值对大小写敏感,在emp表中存放的职务字符串全部是大写。注意:在本练习中,如果SALESMAN写成小写或大小写混合,将不会有查询结果输出。,【训练2】显示工资大于等于3000的雇员姓名、职务和工资。输入并执行查询:SELECT ename,job,sal FROM emp WHERE sal=3000;执行结果为:ENAME JOB SAL-SCOTT ANALYST 3000KING PRESIDENT 5000FORD ANALYST 3000,说明:结果只显示工资大于等于3000的雇员。缺省中文日期格式为DD-MM月-YY,如2003年1月10日应该表示为“10-1月-03”。【训练3】显示1982年以后雇佣的雇员姓名和雇佣时间。输入并执行查询:SELECT ename,hiredate FROM emp WHERE hiredate=1-1月-82;执行结果为:ENAME HIREDATE-,SCOTT 19-4月-87ADAMS 23-5月-87MILLER 23-1月-82说明:检查hiredate字段的内容,都在82年以后。【练习1】显示部门编号为10的雇员姓名和雇佣时间。,2.3.2 复合条件查询可以用逻辑运算符构成复合的条件查询,即把两个或多个条件,用逻辑运算符连接成一个条件。有3个逻辑运算符,如表2-3所示。,表2-3 逻辑运算符,运算的优先顺序是NOT,AND,OR。如果要改变优先顺序,可以使用括号。下面是使用逻辑与运算的练习。1使用逻辑与【训练1】显示工资在10002000之间(不包括1000和2000)的雇员信息。,输入并执行查询:SELECT ename,job,sal FROM emp WHERE sal1000 AND sal2000;执行结果为:ENAME JOB SAL-ALLEN SALESMAN 1600WARD SALESMAN 1250MARTIN SALESMAN 1250TURNER SALESMAN 1500ADAMS CLERK 1100MILLER CLERK 1300,说明:两个条件需要同时满足,所以必须使用AND运算。注意:条件sal1000 AND sal1000 AND 2000。,【练习1】显示部门10中工资大于1500的雇员。2使用逻辑或下面是使用逻辑或运算的练习。【训练2】显示职务为CLERK或MANAGER的雇员信息。输入并执行查询:SELECT*FROM emp WHERE job=CLERK OR job=MANAGER;执行结果从略。说明:检索职务为CLERK或MANAGER的雇员,需要使用OR运算,请自行察看结果。注意:条件job=CLERK OR job=MANAGER不能写成job=CLERK OR MANAGER。,3使用逻辑非下面是使用逻辑非运算的练习。【训练3】显示部门10以外的其他部门的雇员。输入并执行查询:SELECT*FROM emp WHERE NOT deptno=10;执行结果从略。说明:执行结果包含部门编号不等于10的其他部门的雇员,请自行察看结果。,4使用逻辑或和逻辑与下面是同时使用逻辑或和逻辑与的复合练习。【训练4】显示部门10和部门20中工资小于1500的雇员。输入并执行查询SELECT*FROM emp WHERE(deptno=10 OR deptno=20)AND sal1500;,执行结果为:EMPNO ENAME JOB MGR HIREDATE SAL COMM DEPTNO-7369 SMITH CLERK 7902 17-12月-80 800 20 7876 ADAMS CLERK 7788 23-5月-87 1100 20 7934 MILLER CLERK 7782 23-1月-82 1300 10注意:该练习中的括号是不可省的。如果省略,意义有所不同。,【练习2】请说明在如上练习中如果省略括号,该语句所代表的含义和查询的结果。2.3.3 条件特殊表示法使用如表2-4所示的特殊运算表示法,可使语句更为直观,易于理解。,表2-4 特殊运算符,表2-4 特殊运算符,1BETWEEN的用法对于数值型或日期型数据,表示范围时可以用以下的特殊运算表示方法:NOT BETWEEN.AND.【训练1】显示工资在10002000之间的雇员信息。输入并执行查询:SELECT*FROM emp WHERE sal BETWEEN 1000 AND 2000;执行结果从略。注意:下限在前,上限在后,不能颠倒。查询范围中包含上下限的值,因此在本例中,查询工资包含1000和2000在内。请自行执行并察看结果。,2IN的用法使用以下运算形式,可以显示值满足特定集合的结果:NOT IN(.)【训练2】显示职务为“SALESMAN,“CLERK”和“MANAGER”的雇员信息。输入并执行查询:SELECT*FROM emp WHERE job IN(SALESMAN,CLERK,MANAGER);执行结果从略。注意:如果在IN前面增加NOT,将显示职务不在集合列表中的雇员。以上用法同样适用于数值型集合,请自行执行并察看结果。,【练习1】显示部门10和20的雇员信息。3LIKE的用法使用LIKE操作符可完成按通配符查找字符串的查询操作,该操作符适合于对数据进行模糊查询。其语句法为:NOT LIKE 匹配模式匹配模式中除了可以包含固定的字符之外,还可以包含以下的通配符:%:代表0个或多个任意字符。_:代表一个任意字符。,【训练3】显示姓名以“S”开头的雇员信息。输入并执行查询:SELECT*FROM emp WHERE ename LIKE S%;执行结果为:EMPNO ENAME JOB MGR HIREDATE SAL COMM DEPTNO-7369 SMITH CLERK 7902 17-12月-80 800 207788 SCOTT ANALYST7566 19-4月-87 3000 20说明:SMITH和SCOTT名字均以S开头,名字后边的字符和长度任意。,【训练4】显示姓名第二个字符为“A”的雇员信息。执行查询:SELECT*FROM emp WHERE ename LIKE _A%;执行结果从略,请自行执行并察看结果。说明:“_”代表第一个字符任意,第二个字符必须为“A”,“%”代表第二个字符后面的字符为任意字符,个数任意。,【练习2】显示姓名中包含字符“A”的雇员信息。4判断空值NULL在表中,字段值可以是空,表示该字段没有内容。如果不填写,或设置为空则我们说该字段的内容为NULL。NULL没有数据类型,也没有具体的值,但是使用特定运算可以判断出来。这个运算就是:IS NOT NULL,【训练5】显示经理编号没有填写的雇员。输入并执行查询:SELECT ename,mgr FROM emp WHERE mgr IS NULL;执行结果为:ENAME MGR-KING注意:以下用法是错误的。SELECT ename,mgr FROM emp WHERE mgr=NULL;,2.4 函数,2.4.1 数值型函数常用的数值型函数如表2-5所示。,表2-5 数值型函数,【训练1】使用数值型函数练习。步骤1:使用求绝对值函数abs。SELECT abs(?5)FROM dual;执行结果:ABS(?5)-5说明:求?5的绝对值,结果为5。步骤2:使用求平方根函数sqrt。SELECT sqrt(2)FROM dual;执行结果:SQRT(2)-1.41421356说明:2的平方根为1.41421356。,步骤3:使用ceil函数。SELECT ceil(2.35)FROM dual;执行结果:CEIL(2.35)-3说明:该函数求得大于等于2.35的最小整数,结果为3。,步骤4:使用floor函数。SELECT floor(2.35)FROM dual;执行结果:FLOOR(2.35)-2说明:该函数求得小于等于2.35的最大整数,结果为2。,步骤5:使用四舍五入函数round。SELECT round(45.923,2),round(45.923,0),round(45.923,?1)FROM dual;执行结果:ROUND(45.923,2)ROUND(45.923,0)ROUND(45.923,?1)-45.92 46 50说明:该函数按照第二个参数指定的位置对第一个数进行四舍五入。2代表对小数点后第三位进行四舍五入,0 代表对小数位进行四舍五入,?1代表对个位进行四舍五入。,步骤6:使用截断函数trunc。SELECT trunc(45.923,2),trunc(45.923),trunc(45.923,?1)FROM dual;执行结果:TRUNC(45.923,2)TRUNC(45.923)TRUNC(45.923,?1)-45.92 45 40说明:该函数按照第二个参数指定的位置对第一个数进行截断。2代表对小数点后第三位进行截断,0 代表对小数位进行截断,?1代表对个位进行截断。,步骤7:使用求余数函数mod。SELECT mod(1600,300)FROM dual;执行结果:MOD(1600,300)-100说明:1600除以300的商为5,余数为100。,步骤8:使用cos函数。SELECT cos(3.14159)FROM dual;执行结果:COS(3.14159)-?1 说明:cos函数的输入参数应为弧度,3.14159的cos值为?1。函数可以嵌套使用,看如下例子。,【训练2】求|sin(230o)|的值,保留一位小数。步骤1:执行查询。SELECT sin(230*3.14159/180)FROM dual;结果为:SIN(230*3.14159/180)-?.76604226说明:先将230o转换成为弧度,然后进行计算求值。,步骤2:求绝对值。SELECT abs(sin(230*3.14159/180)FROM dual;结果为:ABS(SIN(230*3.14159/180)-.766042264说明:本步骤求绝对值。,步骤3:保留一位小数。SELECT round(abs(sin(230*3.14159/180),1)FROM dual;结果为:ROUND(ABS(SIN(230*3.14159/180),1)-.8说明:本步骤进行四舍五入,保留小数点后1位。【练习1】求23/2,四舍五入,保留一位小数。,2.4.2 字符型函数字符型函数包括大小写转换和字符串操作函数。大小写转换函数有3个。常用的字符型函数如表2-6所示。,表2-6 字符函数,【训练1】如果不知道表的字段内容是大写还是小写,可以转换后比较。输入并执行查询:SELECT empno,ename,deptnoFROM empWHERE lower(ename)=blake;结果为:EMPNO ENAME DEPTNO-7698 BLAKE 30说明:该查询将表中的雇员名转换成小写,与小写的blake进行比较。,【训练2】显示雇员名称和职务列表。输入并执行查询:SELECT concat(rpad(ename,15,.),job)as 职务列表 FROM emp;结果为:职务列表-SMITH.CLERKALLEN.SALESMANWARD.SALESMAN说明:rpad函数向字符串的右侧添加字符,以达到指定宽度。该例中雇员名称右侧连接若干个“.”,凑足15位,然后与雇员职务连接成列表。本例中使用了函数的嵌套。,【训练3】显示名称以“W”开头的雇员,并将名称转换成以大写开头。输入并执行查询:SELECT empno,initcap(ename),job FROM empWHERE substr(ename,1,1)=W;结果为:EMPNO INITCAP(EN JOB-7521 Ward SALESMAN,说明:本例在字段列表和查询条件中分别应用了函数initcap和substr。函数initcap将雇员名称转换成以大写开头。函数substr返回ename从第一个字符位置开始,长度为1的字符串,即第一个字符,然后同大写W比较。,【训练4】显示雇员名称中包含“S”的雇员名称及名称长度。输入并执行查询:SELECT empno,ename,length(ename)FROM empWHERE instr(ename,S,1,1)0;执行结果为:EMPNO ENAME LENGTH(ENAME)-7369 SMITH 5 7566 JONES 5,【训练4】显示雇员名称中包含“S”的雇员名称及名称长度。输入并执行查询:SELECT empno,ename,length(ename)FROM empWHERE instr(ename,S,1,1)0;执行结果为:EMPNO ENAME LENGTH(ENAME)-7369 SMITH 5 7566 JONES 5,说明:本例在字段列表和查询条件中分别应用了函数length和instr。Length函数返回ename的长度。instr(ename,S1,1)函数返回ename中从第一个字符位置开始,字符串“S”第一次出现的位置。如果函数返回0,则说明ename中不包含字符串“S”;如果函数返回值大于0,则说明ename中包含字符串“S”。,【练习1】显示部门表中部门和所在城市列表,中间以下划线“_”连接,城市名转换成以大写字母开头。2.4.3 日期型函数Oracle使用内部数字格式来保存时间和日期,包括世纪、年、月、日、小时、分、秒。缺省日期格式为 DD-MON-YY,如“08-05月-03”代表2003年5月8日。SYSDATE是返回系统日期和时间的虚列函数。使用日期的加减运算,可以实现如下功能:*对日期的值加减一个天数,得到新的日期。,*对两个日期相减,得到相隔天数。*通过加小时来增加天数,24小时为一天,如12小时可以写成12/24(或0.5)。还有如表2-7所示的日期函数可以使用。,表2-7 日期函数,【训练1】返回系统的当前日期。输入并执行查询:SELECT sysdate FROM dual;返回结果为:SYSDATE-06-2月-03说明:该查询返回执行该查询时的数据库服务器的系统当前时间,日期显示格式为默认格式,如“06-2月-03”表示03年2月6日。,【训练2】返回2003年2月的最后一天。输入并执行查询:SELECT last_day(08-2月-03)FROM dual;返回结果为:LAST_DAY(-28-2月-03说明:该函数给定参数为某月份的任意一天,返回时间为该月份的最后一天。本例中,参数为03年2月8号,返回日期为03年2月28日,是该月的最后一天。,【训练3】假定当前的系统日期是2003年2月6日,求再过1000天的日期。输入并执行查询:SELECT sysdate+1000 AS NEW DATE FROM dual;返回结果为:NEW DATE-04-11月-05说明:该查询使用到了日期的加法运算,求经过一定天数后的新日期。,【训练4】假定当前的系统日期是2003年2月6日,显示部门10雇员的雇佣天数。输入并执行查询:SELECT ename,round(sysdate-hiredate)DAYSFROM empWHERE deptno=10;返回结果为:ENAME DAYS-CLARK 7913KING 7752MILLER 7685说明:该查询使用日期的减法运算求两个日期的相差天数。用round函数对天数进行四舍五入。,【练习1】显示雇员名称和雇佣的星期数。【练习2】显示从本年1月1日开始到现在经过的天数(当前时间取SYSDATE的值)。2.4.4 转换函数Oracle的类型转换分为自动类型转换和强制类型转换。常用的类型转换函数有TO_CHAR、TO_DATE或TO_NUMBER,如表2-8所示。,表2-8 类型转换函数,1自动类型转换Oracle可以自动根据具体情况进行如下的转换:*字符串到数值。*字符串到日期。*数值到字符串。*日期到字符串。以下是自动转换的训练。,【训练1】自动转换字符型数据到数值型。输入并执行查询:SELECT 12.5+11 FROM dual;执行结果为:12.5+11-23.5说明:在本训练中,因为出现+运算符,说明进行的是算术运算,所以字符串12.5被自动转换成数值12.5,然后参加运算。,【训练2】自动转换数值型数据到字符型。执行以下查询:SELECT 12.5|11 FROM dual;结果为:12.5-12.511说明:在本训练中,因为出现|运算符,说明进行的是字符串连接运算,数值11被自动转换成字符串11,然后参加运算。,2日期类型转换将日期型转换成字符串时,可以按新的格式显示。如格式YYYY-MM-DD HH24:MI:SS表示“年-月-日 小时:分钟:秒”。Oracle的日期类型是包含时间在内的。主要的日期格式字符的含义如表2-9所示。,表2-9 日期转换格式字符,表2-9 日期转换格式字符,【训练3】将日期转换成带时间和星期的字符串并显示。执行以下查询:SELECT TO_CHAR(sysdate,YYYY-MM-DD HH24:MI:SS AM DY)FROM dual;结果为:TO_CHAR(SYSDATE,YYYY-MM-DD HH24-2004-02-07 15:44:48 下午 星期六,说明:该语句中的第一个参数表示要转换的日期,第二个参数是格式字符串,表示转换后的格式,结果类型为字符串。“YYYY”为4位的年份,“MM”为两位的月份,“DD”为两位的日期,“HH24”表示显示24小时制的小时,“MI”表示显示分钟,“SS”表示显示秒,“AM”表示显示上午或下午(本例中为下午),“DY”表示显示星期。“-”、“:”和空格原样显示,用于分割日期和时间。转换出来的系统时间为:2004年2月7日(星期六)下午15点44分48秒。还可以按其他的格式显示。以下查询中插入中文的年月日,其中原样显示部分区别于外层的单引号,需要用双引号引起。,【训练4】将日期显示转换成中文的年月日。输入并执行查询:SELECT TO_CHAR(sysdate,YYYY年MM月DD日)FROM dual;执行结果为:TO_CHAR(SYSDAT-2003年11月18日说明:双引号中的中文字“年”、“月”、“日”原样显示,单引号为字符串的界定标记,区别于双引号,不能混淆。,【训练5】将雇佣日期转换成字符串并按新格式显示。输入并执行查询:SELECTename,to_char(hiredate,DD Month YYYY)HIREDATEFROM emp;执行结果为:ENAME HIREDATE-SMITH 17 12月 1980ALLEN 20 2月 1981,说明:Month表示月份的特殊格式,如“12月”。年度用4位显示。对于数字型的日期格式,可以用数字或全拼格式显示,即在格式字符后面添加TH或SP。TH代表序列,SP代表全拼。,【训练6】以全拼和序列显示时间。执行以下查询:SELECT SYSDATE,to_char(SYSDATE,yyyysp),to_char(SYSDATE,mmspth),to_char(SYSDATE,ddth)FROM dual;执行结果为:SYSDATE TO_CHAR(SYSDATE,YYYYSP)TO_CHAR(TO_C-,07-2月-04 two thousand four second 07th说明:“two thousand four”为全拼表示的2004年;“second”为全拼序列表示的2月;“07th”为用序列表示的7号。在格式字符中,前两个字符代表显示结果的大小写。如果格式中的前两个字符是大写,则输出结果的全拼也为大写。如果格式中的前两个字符是小写,则输出结果的全拼也为小写。如果格式中的前两个字符的第一个字符是大写,第二个字符是小写,则输出结果的全拼也为大写开头,后面为字符小写。,【训练7】时间显示的大小写。步骤1:执行以下查询:SELECT SYSDATE,to_char(SYSDATE,yyyysp)FROM dual;结果为:SYSDATE TO_CHAR(SYSDATE,YYYYSP)-07-2月-04 two thousand four步骤2:执行以下查询:SELECT to_char(SYSDATE,Yyyysp)FROM dual;结果为:SYSDATE TO_CHAR(SYSDATE,YYYYSP)-Two Thousand Four,步骤3:执行以下查询:SELECT SYSDATE,to_char(SYSDATE,YYyysp)FROM dual;结果为:SYSDATE TO_CHAR(SYSDATE,YYYYSP)-TWO THOUSAND FOUR说明:步骤1输出全拼小写的年度,步骤2输出全拼的以大写开头的年度,步骤3输出全拼大写的年度。【练习1】显示2008年的8月8日为星期几。,3数字类型转换 将数字型转换成字符串时,也可以按新的格式显示。格式字符含义如表2-10所示。,表2-10 数值转换符,【训练8】将数值转换成字符串并按新格式显示。执行以下查询:SELECT TO_CHAR(123.45,0000.00),TO_CHAR(12345,L9.9EEEE)FROM dual;结果为:TO_CHAR(TO_CHAR(12345,L9.9-0123.45 RMB1.2E+04说明:格式字符串中“0”表示一位数字,转换结果中相应的位置上没有数字则添加0。“.”表示在相应的位置上显示小数点。“L”将以本地货币符号显示于数字前,在本例中本地货币符号为“RMB”。“EEEE”将显示转换为科学计数法。,【训练9】将数值转换成字符串并按新格式显示。执行以下查询:SELECT TO_CHAR(sal,$99,999)SALARY FROM empWHERE ename=SCOTT;结果为:SALARY-$4,000说明:格式字符串中“$”表示转换结果前面添加$。“9”表示一位数字,“99,999”表示结果可以显示为5位的数字。“,”表示在相应的位置上添加逗号。如果实际数值位数不足5位,则只显示实际位数,如4000实际位数为4位,则只显示4位。如果实际位数超过5位,则会填充为#号。,2.4.5 其他函数Oracle还有一些函数,如decode和nvl,这些函数也很有用,归纳如表2-11所示。,表2-11 其他常用函数,1空值的转换如果对空值NULL不能很好的处理,就会在查询中出现一些问题。在一个空值上进行算术运算的结果都是NULL。最典型的例子是,在查询雇员表时,将工资sal字段和津贴字段comm进行相加,如果津贴为空,则相加结果也为空,这样容易引起误解。使用nvl函数,可以转换NULL为实际值。该函数判断字段的内容,如果不为空,返回原值;为空,则返回给定的值。,如下3个函数,分别用新内容代替字段的空值:nvl(comm,0):用0代替空的Comm值。nvl(hiredate,01-1月-97):用1997年1月1日代替空的雇佣日期。nvl(job,无):用“无”代替空的职务。,【训练1】使用nvl函数转换空值。执行以下查询:SELECTename,nvl(job,无),nvl(hiredate,01-1

    注意事项

    本文(SQL数据库基础培训.ppt)为本站会员(牧羊曲112)主动上传,三一办公仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知三一办公(点击联系客服),我们立即给予删除!

    温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




    备案号:宁ICP备20000045号-2

    经营许可证:宁B2-20210002

    宁公网安备 64010402000987号

    三一办公
    收起
    展开