oracle存储过程----case条件控制语句的用法

上一篇 oracle存储过程—-赋值、相等、分支的写法

oracle存储过程—-case条件控制语句的用法

  今天又看到了另一种条件控制的方法case

case语句可以分为两种类型:
  1. 一种是简单的case语句,它给出一个表达式,并把表达式结果同提供的几个可预见的结果作比较,如果比较成功,则执行对应的语句序列。
  2. 另一种是搜索式的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;

  分别输入 12 调用后的结果如下:

匿名块已完成
男人

匿名块已完成
女人

  从上边来看,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 后边的条件是否为truetrue 则进入。
  另外,上边的else 如果不写,假如没有符合条件的when ,也会抛出CASE_NOT_FOUND 异常。

下一篇 oracle存储过程—-异常的写法介绍

  • 3
    点赞
  • 26
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 3
    评论
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

茁壮成长的凌大大

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值