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