2.2.3程序控制语句
机构化程序设计语言分顺序、循环、分支3中结构,PL/SQL提供了一系列的控制和跳转语句来支持这3种结构。
1.条件控制语句
最常用的是IF-THEN-ELSE语句,IF用来检查指定表达式的条件:THEN在条件中的值为True时执行代码:ELSE在条件值为False或NULL时执行代码。在IF条件中可以使用布尔表达式包含多个条件,也可以使用IF-THEN-ELSIF语句来进行多条件判断。
如果要判断的条件过多,可以使用CASE语句,CASE语句可以仅检查一次条件判断的值,然后判断这个值在多种条件下的实现。
create or replace function getMarkByCaseWhen(score in number) --传入学生成绩
return varchar2 is --返回绩点
v_mark varchar2(2);
begin
case
when score > 90 then --根据成绩进行判断
v_mark := 'A';
when score > 80 then
v_mark := 'B';
when score > 70 then
v_mark := 'C';
when score >= 60 then
v_mark := 'D';
when score < 60 then
v_mark := 'F';
end case;
return v_mark;
end;
代码使用了CASE-WHEN语句后,在调用时与IF-THEN-ELSE能产生相同的效果,但是两者有一个区别:当CASE发现一个when**子句不存在判断条件时,会触发异常。
2.循环控制语句
PL/SQL 提供了三种类型的循环,如下所示:
(1)简单循环:这是最基础的循环类型,包含LOOP-END LOOP和用来退出循环的EXIT方法。
(2)数字FOR式循环:将会循环指定次数退出循环。
(3)WHILE循环:仅当条件成立时才执行循环。
以下展示如何使用数字式FOR循环打印九九乘法口诀表,定义代码如下:
--通过循环打印输出九九乘法表
declare
--定义外层循环数
v_num1 number;
--定义内层循环数
v_num2 number;
begin
--第一层循环
for v_num1 in 1 .. 9 loop
--第二层循环从1开始到第一层结束
for v_num2 in 1 .. v_num1 loop
dbms_output.put(v_num2
||'*'
|| v_num1
||'='
||v_num1*v_num2
||' '
);
end loop;
dbms_output.put_line('');
end loop;
end;
结果
为了打印九九乘法口诀表,使用了两个FOR循环,内层FOR根据外层FOR的循环次数来决定最大的计数。