Oracle
 sql >> Base de Dados >  >> RDS >> Oracle

número errado ou tipos de argumentos na chamada para o meu procedimento


Se você não precisar do segundo e terceiro argumentos, poderá declará-los como variáveis ​​no procedimento em vez de argumentos, da seguinte maneira:
CREATE OR REPLACE PROCEDURE DDPAY_SP(DONOR_ID IN  DD_DONOR.IDDONOR%TYPE,
                                     RET      OUT BOOLEAN)
IS
  nPayment_count  NUMBER;
BEGIN 
  SELECT COUNT(*)
    INTO nPayment_count  
    FROM DD_PLEDGE p
    WHERE p.IDDONOR = DONOR_ID AND
          p.IDSTATUS = 10 AND
          p.PAYMONTHS > 0;

  IF nPayment_count > 0 THEN
    RET := TRUE;
  END IF;
EXCEPTION
  WHEN OTHERS THEN
    DBMS_OUTPUT.PUT_LINE('DD_PAY - exception: ' || SQLCODE || ' : ' || SQLERRM);
    RAISE;
END DDPAY_SP;

Incluí um exemplo de um manipulador EXCEPTION no final de DD_PAY. É sempre uma boa ideia incluir pelo menos esse manipulador mínimo para que, no caso de ocorrer uma exceção, você tenha alguma indicação de onde está o problema.

Como esse procedimento retorna um valor BOOLEAN e os BOOLEANs não podem (até onde eu sei) ser usados ​​do SQL*Plus, você terá que invocá-lo de um bloco PL/SQL, da seguinte forma:
DECLARE
  bRetval  BOOLEAN;
BEGIN
  DD_PAY(308, bRetval);
  DBMS_OUTPUT.PUT_LINE('Returned value is ' ||
                       CASE bRetval
                         WHEN TRUE THEN 'TRUE'
                         ELSE 'FALSE'
                       END);
END;

Tente isso.

EDIT:reescreveu o procedimento com base em mais informações de comentários posteriores.

Compartilhe e curta.