Oracle
 sql >> база данни >  >> RDS >> Oracle

грешен номер или типове аргументи в извикването на моята процедура

Ако нямате нужда от втория и третия аргумент, можете да ги декларирате като променливи в процедурата вместо аргументи, както следва:

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;

Включих пример за манипулатор EXCEPTION в края на DD_PAY. Винаги е добра идея да включите поне този минимален манипулатор, така че в случай на изключение да получите известна индикация къде се крие проблемът.

Тъй като тази процедура връща BOOLEAN стойност и BOOLEANs не могат (доколкото ми е известно) да се използват от SQL*Plus, ще трябва да я извикате от PL/SQL блок, както следва:

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;

Опитайте.

РЕДАКТИРАНЕ:пренаписана процедура въз основа на допълнителна информация от по-късни коментари.

Споделяйте и се наслаждавайте.




  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. 2 начина за връщане на редове, които не съдържат числови стойности в Oracle

  2. Как да предадете XML като параметър към съхранената процедура в Oracle

  3. Има ли .Net интерфейс към Oracle SQLPLUS?

  4. Oracle С КЛАУЗА не работи?

  5. ORA-12518, TNS:слушател не можа да прехвърли клиентска връзка