数据库函数给出参设置默认值

当Oracle数据库函数根据输入参数执行SQL查询无结果时,通常会出现'No Data found'异常。为了处理这种情况,可以不使用IF语句,而是利用异常处理机制。通过捕获并处理'NO_DATA_FOUND'异常,可以确保函数在找不到数据时返回输入参数。了解更多详情,可参考相关文章。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

create or replace function getStkCode(p_gzcode   varchar2)
	return varchar2 as
	v_stkcode varchar2(100);
begin
	with temp_kvs_stkgzcode as(select * from srv_kvs_stkgzcode)
	select stkcode
	 into v_stkcode
	 from temp_kvs_stkgzcode a
	where a.GZCODE = p_gzcode and rownum = 1 ;
	return v_stkcode;
   exception
     when NO_DATA_FOUND  then v_stkcode :=p_gzcode;
   return v_stkcode;
END;

如果根据入参执行sql查不到数据,就把入参返回给出参;
如果sql查不到数据,into的时候就会报异常:No Data found,该处为异常并不适合使用IF,所以通过捕获异常处理。

参考:oracle的异常https://blog.youkuaiyun.com/xu810260277/article/details/89166559

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值