sql >> Databáze >  >> RDS >> Oracle

nesprávný počet nebo typy argumentů ve volání mé procedury

Pokud nepotřebujete druhý a třetí argument, můžete je v proceduře deklarovat jako proměnné místo argumentů, a to následovně:

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;

Zahrnul jsem příklad obsluhy EXCEPTION na konec DD_PAY. Vždy je dobré zahrnout alespoň tento minimální obslužný program, abyste v případě, že dojde k výjimce, získali určitou informaci o tom, kde je problém.

Protože tato procedura vrací hodnotu BOOLEAN a hodnoty BOOLEAN nelze (podle mého nejlepšího vědomí) použít z SQL*Plus, budete ji muset vyvolat z bloku PL/SQL následovně:

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;

Zkuste to.

EDIT:přepsán postup na základě dalších informací z pozdějších komentářů.

Sdílejte a užívejte si.




  1. Databázi 'xxx' nelze otevřít, protože je verze 904

  2. Pole JPA @Version se nezvyšuje

  3. Je bezpečné ukládat uživatelská jména a hesla do databáze?

  4. Tabulky vs. databáze:Je čas přejít? Část 1