oracle存储过程—-case条件控制语句的用法
今天又看到了另一种条件控制的方法case
。
case语句可以分为两种类型:
- 一种是简单的case语句,它给出一个表达式,并把表达式结果同提供的几个可预见的结果作比较,如果比较成功,则执行对应的语句序列。
- 另一种是搜索式的case语句。它会提供多个布尔表达式,然后选择第一个为true的表达式,执行对应的脚本。
1.简单case语句
简单case的语法如下:
create or replace procedure test_case_procedure(idnum varchar)
as
v_ly_ds ly_ds%rowtype;
begin
select * into v_ly_ds from ly_ds where id=idnum;
case v_ly_ds.ly_nb
when '女' then
dbms_output.put_line('女人');
when '男' then
dbms_output.put_line('男人');
else
dbms_output.put_line('人妖');
end case;
end;
分别输入 1
、2
调用后的结果如下:
匿名块已完成
男人
匿名块已完成
女人
从上边来看,case
的简单语法如下:
case 标志
when 参数1 then
语句块1;
when 参数2 then
语句块2;
else
语句块3;
end case;
执行过程中是,从上到下,依次拿when
后边的参数,分别与上边的标志
进行比较,相等
则进入。
另外,上边的else
如果不写,假如没有符合条件的when
,则会抛出CASE_NOT_FOUND
异常。
2.搜索式case语句
搜索式case与简单式差不多,只不过是搜索式的这种,case后边是没有参数的。
将上边的例子,修改后如下,即是搜索式case:
create or replace procedure test_case_procedure(idnum varchar)
as
v_ly_ds ly_ds%rowtype;
begin
select * into v_ly_ds from ly_ds where id=idnum;
case
when v_ly_ds.ly_nb='女' then
dbms_output.put_line('女人');
when v_ly_ds.ly_nb='男' then
dbms_output.put_line('男人');
else
dbms_output.put_line('人妖');
end case;
end;
执行过程与上边相同。
从上边来看,搜索式的case语法如下:
case
when 条件1 then
语句块1;
when 条件2 then
语句块2;
else
语句块3;
end case;
执行过程中是,从上到下,依次看when
后边的条件是否为true
,true
则进入。
另外,上边的else
如果不写,假如没有符合条件的when
,也会抛出CASE_NOT_FOUND
异常。