Plsql 调用我的过程时参数的数目或类型错误

Plsql 调用我的过程时参数的数目或类型错误,plsql,oracle11g,Plsql,Oracle11g,您好,我编写这段代码是为了创建一个过程,根据if条件返回布尔值,但当我执行它时,出现以下错误: ORA-06550: line 1, column 7: PLS-00306: wrong number or types of arguments in call to 'DDPAY_SP' ORA-06550: line 1, column 7: PL/SQL: Statement ignored 06550. 00000 - "line %s, column %s:\n%s" *Cause:

您好,我编写这段代码是为了创建一个过程,根据if条件返回布尔值,但当我执行它时,出现以下错误:

ORA-06550: line 1, column 7:
PLS-00306: wrong number or types of arguments in call to 'DDPAY_SP'
ORA-06550: line 1, column 7:
PL/SQL: Statement ignored
06550. 00000 -  "line %s, column %s:\n%s"
*Cause:    Usually a PL/SQL compilation error.
*Action:
这是我的程序

create or replace procedure  DDPAY_SP (

donor_id dd_donor.iddonor%type,
pldgstatus out dd_pledge.idstatus%type,
monthplan  out dd_pledge.paymonths%type,
ret out boolean)
IS
begin

select idstatus, paymonths into
pldgstatus, monthplan from dd_pledge 
where iddonor = donor_id ;

if (pldgstatus = 10 AND monthplan >0)
then ret:= true;
else
ret:= false;
end if;

end;
这就是我执行它的方式

 EXECUTE DDPAY_SP (308);
我没说太多我希望你能明白

我在线阅读,它建议我检查命名和数据类型,我做了,但没有任何改变


任何想法

如果不需要第二个和第三个参数,可以在过程中将它们声明为变量,而不是参数,如下所示:

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;
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;
我在DD_PAY的末尾包含了一个异常处理程序的示例。最好至少包含这个最小的处理程序,这样在发生异常时,您就可以知道问题所在

因为这个过程返回一个布尔值,而且(据我所知)布尔值不能从SQL*Plus中使用,所以您必须从PL/SQL块中调用它,如下所示:

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;
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个输入值和3个输出变量。您只提供了输入值。@BobJarvis但是为什么我要提供输出…顺便说一句,问题是只要求一个布尔值(真/假),而不是两个变量,但我声明了它们,因为在此之前我得到了错误,我想这是由于它们不存在,所以我只声明了它们。要运行SQL语句,但我不需要输出它们,那么如何编写执行语句呢?我得到的是一个dude ORA-01422:exact fetch返回的行数超过了请求的行数ORA-06512:at“SYSTEM.DDPAY_SP”,第20行ORA-06512:at第4 01422行。00000-“精确提取返回的行数大于请求的行数”*原因:精确提取中指定的行数小于返回的行数*措施:重写查询或更改请求的行数我再次测试了它,但使用了不同的id\u donor值,我发现如果此值在dd\u保证中只有行,它只会给我“匿名块已完成”,既不为true也不为false…..但是如果该值有多行,则会发生错误???对不起,我的错误出现在DBMS输出窗口中未连接到我的架构,因此我无法查看输出…但是如果iddonnor有多行,我仍然会得到“精确获取返回的行数超过请求的行数”@user2396035:问题是,对于给定的IDDONOR,DD_质押中存在多行,这是我不可能知道的。没问题-我已经重写了处理这种情况的程序。分享和享受。我测试了它,现在看起来很好…但有一件事我发现很奇怪,当我测试不同的行,其中idstatus=20和paymorns=0时,它给我假“这就是我所期望的”,所有情况下,期望一个情况它给我真的!!!!