ImageVerifierCode 换一换
格式:PPT , 页数:14 ,大小:62.50KB ,
资源ID:388398      下载积分:2000 积分
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝扫码支付 微信扫码支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【http://www.mydoc123.com/d-388398.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(第15章Oracle中的控制语句.ppt)为本站会员(diecharacter305)主动上传,麦多课文库仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知麦多课文库(发送邮件至master@mydoc123.com或直接QQ联系客服),我们立即给予删除!

第15章Oracle中的控制语句.ppt

1、第15章 Oracle中的控制语句,所有编程语言都离不开控制语句,Oracle也为PL/SQL编程提供了基本的控制语句。本章将针对最主要的两种控制语句:条件控制语句和循环语句进行讲解。本章内容包括: 条件语句:if else; 条件语句:case when; 循环语句:无条件循环; 循环语句:while循环; 循环语句:for循环。,15.1 Oracle中的条件语句,条件语句是指通过条件判断改变程序流程的语句。Oracle中提供了两种主要的条件语句:if else语句和case语句。,15.1.1 利用if else进行条件判断,if else语句是编程语言中最常见的条件控制语句。if关键字

2、之后需要紧跟条件表达式,当该条件表达式返回为真时,将执行其后的语句,否则,将执行else之后的语句。 declare employee_num number; begin select count(*) into employee_num from t_employees where status = ACT;if employee_num0 then dbms_output.put_line(表T_EMPLOYEES中存在记录); else dbms_output.put_line(表T_EMPLOYEES中不存在记录); end if; end;,15.1.1 利用if else进行条件判

3、断,declare employee_num number; begin select count(*) into employee_num from t_employees where status = ACT;if employee_num1 then dbms_output.put_line(表T_EMPLOYEES中存在多条有效记录); elsif employee_num = 1 then dbms_output.put_line(表T_EMPLOYEES中仅存在一条有效记录); else dbms_output.put_line(表T_EMPLOYEES中不存在记录); end i

4、f; end; 注意:此处条件判断的写法,elsif不能写作else if。,15.1.2 利用case when进行分支判断,使用if else,当条件分支很多时,将不得不使用多个elsif分支。从Oracle 9i开始,可以利用另外一个条件判断的语句来实现多分支判断,这就是case when语句。 declare employee_num number; begin select count(*) into employee_num from t_employees where status = ACT;case when employee_num1 then dbms_output.pu

5、t_line(表T_EMPLOYEES中存在多条有效记录); when employee_num = 1 then dbms_output.put_line(表T_EMPLOYEES中仅存在一条有效记录); else dbms_output.put_line(表T_EMPLOYEES中不存在记录); end case; end;注意与说明: 1case语句,在一种情况满足时,将不会继续匹配下面的条件,而是直接跳出判断语句。 2第二种case方式,只适用于表达式的值在有限,而且确定的范围之内进行匹配;而第一种方式则是使用逻辑判断。,15.2 Oracle中的循环语句,循环语句是除了条件语句之外,

6、另一常用的控制语句。Oracle提供了三种主要的循环语句:无条件循环、while循环和for循环。,15.2.1 无条件循环,Oracle中的无条件循环是指,循环本身并不提供循环条件,而是由exit语句来控制何时跳出循环。 set serverout on; declare num number:=0; v_name varchar2(20); begin loop if num=5 then exit; end if; num := num + 1; select employee_name into v_name from t_employees where employee_id = n

7、um; dbms_output.put_line(num | 号员工是: | v_name); end loop; end; 可以利用exit when来代替if判断。,15.2.2 while循环,while循环也是利用loop循环的形式。只是在loop循环之前添加条件判断,while即用来作为条件的标识。 declare num number:=0; v_name varchar2(20); begin while num 5 loop num := num + 1; select employee_name into v_name from t_employees where emplo

8、yee_id = num;dbms_output.put_line(num | 号员工是: | v_name); end loop; end;,15.2.3 for循环,for循环适用于循环次数确定的情况。for循环会首先评估循环次数,然后针对每次循环都会将循环计数器累加1,直至达到循环次数。 declare v_name varchar2(20); begin for i in 1 5 loop select employee_name into v_name from t_employees where employee_id = i;dbms_output.put_line(i | 号员

9、工是: | v_name); end loop; end;,15.3 本章实例,在Oracle中,同样可以使用嵌套循环,如【范例15-11】所示。 【范例15-11】该范例演示了Oracle中的嵌套循环。 通过本例可以看出,Oracle中的嵌套循环与其他语言中的嵌套循环用法一致。当然,开发者也可以使用其他任意两种循环形式进行嵌套循环。,15.3 本章实例,declare num number:=0;v_name varchar2(20); beginwhile num 5 loopnum := num + 1;select employee_name into v_name from t_em

10、ployees where employee_id = num;dbms_output.put_line(num | 号员工是: | v_name);for i in 1num loopdbms_output.put(*);end loop;dbms_output.put_line();end loop; end;,15.4 本章小结,本章通过几个实例,介绍了如何使用循环语句。Oracle中所有循环的实质都是loop循环。只是根据是否在loop之前指定条件和条件的具体格式,分为无条件循环和while循环、for循环。值得注意的是,无条件循环内部对于exit的处理,一定要保证exit能够成功执行

11、,否则,将会造成死循环。,15.5 习题,1试用case when语句改写以下语句。 if course = 0 then dbms_output.put_line(数学); elsif course = 1 then dbms_output.put_line(语文); elsif course = 2 then dbms_output.put_line(英语); else dbms_output.put_line(其他); end if;,15.5 习题,2试用无条件循环打印表students的雇员信息(包括雇员ID、雇员姓名)。 3利用while循环来完成上题的功能。 4利用for循环计算1100之间所有奇数的和。,

copyright@ 2008-2019 麦多课文库(www.mydoc123.com)网站版权所有
备案/许可证编号:苏ICP备17064731号-1