昨天使用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;