oracle自定义函数返回为空时如何调用

首先是写个创建函数的例子

create or replace function f_getcc(ZYBH IN VARCHAR2)
return VARCHAR2 
is
CC VARCHAR2(200);
begin
   select A into CC  from TABLE where systemid = '5d1905d1ecb247f2b9c96ba9b48fb607' ;
end f_getcc;
/

在创建函数的时候用命令窗口创建,如果有报错 用show error 命令查看

函数体执行结果是返回空值

空值结果
这时候去调用函数f_getcc会报错
报错
尝试用nvl和decode函数将返回值设置为字符串A,但是执行的时候还是报返回值为空。
解决办法是:

create or replace function f_getcc(ZYBH IN VARCHAR2)
return VARCHAR2 
is
CC VARCHAR2(200);
begin
   select A into CC  from TABLE where systemid = '5d1905d1ecb247f2b9c96ba9b48fb607' ;
   return CC;
   Exception
   when others then
   CC :=  '1';
   return CC ;
end f_getcc;
/

函数捕获异常

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值