plsql - 调用我的程序时的参数数量或类型错误

标签 plsql oracle11g

嗨,我写了这段代码来创建一个程序,根据 if 条件返回一个 bool 值,但是当我执行它时,我收到了这个错误:

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;

我在 DD_PAY 的末尾包含了一个 EXCEPTION 处理程序的示例。至少包含这个最小的处理程序总是一个好主意,以便在发生异常的情况下,您将得到问题所在的一些指示。

因为这个过程返回一个 BOOLEAN 值,而 BOOLEAN 不能(据我所知)从 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;

试一试吧。

编辑:根据后来评论中的更多信息重写程序。

分享和享受。

关于plsql - 调用我的程序时的参数数量或类型错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16737141/

相关文章:

oracle - 无法使用 BULK COLLECT 和 FORALL 编译 PL/SQL

sql - 关于sql中的日期

oracle - 为什么在 CLOB 上使用 REPLACE 函数会导致 CACHE_LOBS 增加...?

java - 来自 Oracle PL/SQL 存储过程的 JDBC 结果集

sql - where 子句中的奇怪随机行为

json - 如何在plsql中以json形式发送POST请求

arrays - Groovy代码将字符串数组插入Oracle表

oracle - 如何使用表中的现有行修改 Oracle 中的数据类型

java - Documentum:Oracle数据库Date时间差和I_LATEST_FLAG

java - 如何通过 Eclipse 链接查找查询的解释计划