oracle procedure 对将要赋值进行判断,否则会报异常

当你将查出来的值,into给一个定义的变量的时候,首先判断是否查询出来值。

create or replace procedure  procedureName(
parameterName   in  parameterType
parameterName   out  parameterType 
) 
as
testStr   varchar2(30);
checkNum  ineger;
begin
select  t.col1  into testStr  from   tableA  t   where   t.testVar = condition_str;
/*
当你在执行上面的sql时,可能会出现三种情况:
1. 没有查询出数据,into给testStr  会报 ORA-01403 
2. 查询出多条数据,into给testStr  也会报异常(具体什么忘记了)
3. 查询出一条数据,是正确的
改正,如下:
*/
在执行上面语句前,请添加一句:
select  count(*)   into checkNum   from  tableA  t   where  t.testVar = condition_str;
if   checkNum =0     --查询不存在情况
then
---分别处理
elsif  checkNum >1 --查询大于1情况
then
--分别处理
end if;

end;
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值