




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、第第1515章章 OracleOracle中的控制语句中的控制语句所有编程语言都离不开控制语句,所有编程语言都离不开控制语句,Oracle也为也为PL/SQL编程提供了基本的控制语句。本章将针对最主要的两种控制编程提供了基本的控制语句。本章将针对最主要的两种控制语句:条件控制语句和循环语句进行讲解。本章内容包括:语句:条件控制语句和循环语句进行讲解。本章内容包括:条件语句:条件语句:if else;条件语句:条件语句:case when;循环语句:无条件循环循环语句:无条件循环;循环语句:循环语句:while循环循环;循环语句:循环语句:for循环。循环。15.1 Oracle15.1 Ora
2、cle中的条件语句中的条件语句条件语句是指通过条件判断改变程序流程的语句。条件语句是指通过条件判断改变程序流程的语句。Oracle中提供了两种主要的条件语句:中提供了两种主要的条件语句:if else语句和语句和case语语句。句。15.1.1 15.1.1 利用利用if elseif else进行条件判断进行条件判断if else语句是编程语言中最常见的条件控制语句。语句是编程语言中最常见的条件控制语句。if关关键字之后需要紧跟条件表达式,当该条件表达式返回为真时键字之后需要紧跟条件表达式,当该条件表达式返回为真时,将执行其后的语句,否则,将执行,将执行其后的语句,否则,将执行else之后的
3、语句。之后的语句。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 15.1.1 利用利用if elseif else进行条件判断进行条件判断decla
4、re 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_EMPLOYE
5、ES中不存在记录中不存在记录); end if; end; 注意:此处条件判断的写法,注意:此处条件判断的写法,elsif不能写作不能写作else if。15.1.2 15.1.2 利用利用case whencase when进行分支判断进行分支判断使用使用if else,当条件分支很多时,将不得不使用多个,当条件分支很多时,将不得不使用多个elsif分支。从分支。从Oracle 9i开始,可以利用另外一个条件判断的语句来实现多分支判断,开始,可以利用另外一个条件判断的语句来实现多分支判断,这就是这就是case when语句。语句。declare employee_num number; be
6、gin select count(*) into employee_num from t_employees where status = ACT; case when employee_num1 then dbms_output.put_line(表表T_EMPLOYEES中存在多条有效记录中存在多条有效记录); when employee_num = 1 then dbms_output.put_line(表表T_EMPLOYEES中仅存在一条有效记录中仅存在一条有效记录); else dbms_output.put_line(表表T_EMPLOYEES中不存在记录中不存在记录); end
7、 case; end;注意与说明:注意与说明:1case语句,在一种情况满足时,将不会继续匹配下面的条件,语句,在一种情况满足时,将不会继续匹配下面的条件,而是直接跳出判断语句。而是直接跳出判断语句。2第二种第二种case方式,只适用于表达式的值在有限,而且确定的范方式,只适用于表达式的值在有限,而且确定的范围之内进行匹配;而第一种方式则是使用逻辑判断。围之内进行匹配;而第一种方式则是使用逻辑判断。15.2 Oracle15.2 Oracle中的循环语句中的循环语句循环语句是除了条件语句之外,另一常用的控制语句循环语句是除了条件语句之外,另一常用的控制语句。Oracle提供了三种主要的循环语句
8、:无条件循环、提供了三种主要的循环语句:无条件循环、while循环和循环和for循环。循环。15.2.1 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
9、_name from t_employees where employee_id = num; dbms_output.put_line(num | 号员工是:号员工是: | v_name); end loop; end; 可以利用可以利用exit when来代替来代替if判断。判断。15.2.2 while15.2.2 while循环循环while循环也是利用循环也是利用loop循环的形式。只是在循环的形式。只是在loop循环循环之前添加条件判断,之前添加条件判断,while即用来作为条件的标识。即用来作为条件的标识。declare num number:=0; v_name varchar
10、2(20); begin while num 5 loop num := num + 1; select employee_name into v_name from t_employees where employee_id = num; dbms_output.put_line(num | 号员工是:号员工是: | v_name); end loop; end; 15.2.3 for15.2.3 for循环循环for循环适用于循环次数确定的情况。循环适用于循环次数确定的情况。for循环会首先评循环会首先评估循环次数,然后针对每次循环都会将循环计数器累加估循环次数,然后针对每次循环都会将循环
11、计数器累加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 | 号员工是:号员工是: | v_name); end loop; end; 15.3 15.3 本章实例本章实例在在Oracle中,同样可以使用嵌套循环,如【范例中,同样可以使用嵌套循环,如【范例15-11】所示。】所示。【范例【范例15-11】
12、该范例演示了】该范例演示了Oracle中的嵌套循环。中的嵌套循环。通过本例可以看出,通过本例可以看出,Oracle中的嵌套循环与其他语言中的嵌套循环与其他语言中的嵌套循环用法一致。当然,开发者也可以使用其他任意中的嵌套循环用法一致。当然,开发者也可以使用其他任意两种循环形式进行嵌套循环。两种循环形式进行嵌套循环。15.3 15.3 本章实例本章实例declare num number:=0; v_name varchar2(20);begin while num 5 loop num := num + 1; select employee_name into v_name from t_emp
13、loyees where employee_id = num; dbms_output.put_line(num | 号员工是:号员工是: | v_name); for i in 1.num loop dbms_output.put(*); end loop; dbms_output.put_line(); end loop;end;15.4 15.4 本章小结本章小结本章通过几个实例,介绍了如何使用循环语句。本章通过几个实例,介绍了如何使用循环语句。Oracle中所有循环的实质都是中所有循环的实质都是loop循环。只是根据是否在循环。只是根据是否在loop之前指定条件和条件的具体格式,分为无
14、条件循环和之前指定条件和条件的具体格式,分为无条件循环和while循环、循环、for循环。值得注意的是,无条件循环内部对于循环。值得注意的是,无条件循环内部对于exit的处理,一定要保证的处理,一定要保证exit能够成功执行,否则,将会造能够成功执行,否则,将会造成死循环。成死循环。15.5 15.5 习题习题1试用试用case when语句改写以下语句。语句改写以下语句。if course = 0 then dbms_output.put_line(数学数学);elsif course = 1 then dbms_output.put_line(语文语文);elsif course = 2
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 国企爱国卫生月活动方案
- 商超互动小活动方案
- 售楼部雪茄活动方案
- 国风汉服活动方案
- 固体压强活动方案
- 国庆骑行活动方案
- 团建体验潜水活动方案
- 员工爬山比赛活动方案
- 商业银行送月饼活动方案
- 团队采摘红薯活动方案
- 2025年河南省高考物理真题(解析版)
- 2025中国心肌病综合管理指南要点解读课件
- 7数沪科版期末考试卷-2024-2025学年七年级(初一)数学下册期末考试模拟卷03
- 凉山州木里县选聘社区工作者笔试真题2024
- 2025年中国太平洋人寿保险股份有限公司劳动合同
- 配电线路高级工练习试题附答案
- 护士N2理论考试试题及答案
- 2025年河北省中考麒麟卷地理(二)
- 第23课+和平发展合作共赢的时代潮流+课件高一历史下学期统编版(2019)必修中外历史纲要下
- 小说阅读-2025年中考语文一模试题分项汇编解析版
- 公共组织绩效评估-形考任务一(占10%)-国开(ZJ)-参考资料
评论
0/150
提交评论