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.