OCI_NO_DATA

昨天使用navicat写存储过程的时候,碰到一个问题,运行一直报错error-OCI_NO_DATA,找不到原因,之后将存储过程函数一个个拆分运行,发现有的有数据,有的会报错。用toad for oracle运行报错:oracle 存储过程 ORA-01403: 未找到任何数据 ORA-06512: 在 "…。出现这个问题是因为select into 语句查询到空值,并将空值给了变量,在网上找了很多资料,nvl也试过了,根本没用,最后用异常处理解决了这个问题。在后面加上:
exception when no_data_found then
v_rate := 0;
因为我的项目是有将近27个变量,而exception这个解决方法是只要出现空值,就执行then之后的所有语句,不可能将27个变量都赋值为0,要给每个select into 语句单独写exception语句,所以我给每个select into语句都加了:
begin
select … into …
from …
where …;

exception when no_data_found then
v_rate:=0;

end;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值