Oracle
 sql >> Datenbank >  >> RDS >> Oracle

Kann %NOTFOUND nach einem Abruf null zurückgeben?

Ich kann eine Situation finden, in der ein Abruf fehlschlagen kann:

declare
  i integer;
  cursor c is
    select 1 / 0 from dual;
begin
  open c;

  begin
    fetch c
      into i;
  exception
    when others then
      dbms_output.put_line('ex');
  end;

  if c%notfound is null then
    dbms_output.put_line('null');
  elsif c%notfound then
    dbms_output.put_line('true');
  else
    dbms_output.put_line('false');
  end if;
  close c;

end;

Aber das macht Ihre Frage nur stärker, da sie weder in 10g noch in 11g ...

zu null ausgewertet wird