您好,我编写了这段代码来创建一个过程,根据 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;
我在 DD_PAY 末尾包含了一个异常处理程序的示例。至少包含这个最小处理程序总是一个好主意,这样在发生异常时您将得到一些有关问题所在的指示。
因为此过程返回 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;
尝试一下。
编辑:根据后来评论的进一步信息重写了程序。
分享并享受。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)