Oracle
 sql >> Base de données >  >> RDS >> Oracle

La condition IF EXISTS ne fonctionne pas avec PLSQL

IF EXISTS() est sémantiquement incorrect. EXISTS condition ne peut être utilisée qu'à l'intérieur d'une instruction SQL. Vous pouvez donc réécrire votre bloc pl/sql comme suit :

declare
  l_exst number(1);
begin
  select case 
           when exists(select ce.s_regno 
                         from courseoffering co
                         join co_enrolment ce
                           on ce.co_id = co.co_id
                        where ce.s_regno=403 
                          and ce.coe_completionstatus = 'C' 
                          and ce.c_id = 803
                          and rownum = 1
                        )
           then 1
           else 0
         end  into l_exst
  from dual;

  if l_exst = 1 
  then
    DBMS_OUTPUT.put_line('YES YOU CAN');
  else
    DBMS_OUTPUT.put_line('YOU CANNOT'); 
  end if;
end;

Ou vous pouvez simplement utiliser count la fonction détermine le nombre de lignes renvoyées par la requête, et rownum=1 prédicat - vous avez seulement besoin de savoir si un enregistrement existe :

declare
  l_exst number;
begin
   select count(*) 
     into l_exst
     from courseoffering co
          join co_enrolment ce
            on ce.co_id = co.co_id
    where ce.s_regno=403 
      and ce.coe_completionstatus = 'C' 
      and ce.c_id = 803
      and rownum = 1;

  if l_exst = 0
  then
    DBMS_OUTPUT.put_line('YOU CANNOT');
  else
    DBMS_OUTPUT.put_line('YES YOU CAN');
  end if;
end;