为什么我在PL / SQL中收到此错误

时间:2015-06-29 23:04:10

标签: oracle11g plsqldeveloper

我无法弄清楚为什么我在运行查询时遇到以下错误。完成几乎所有可能的搜索,因为它与我的问题有关。据我所知,代码很好。有什么想法吗?

ORA-06550:第17行,第42栏: PLS-00201:标识符' IDPLEDGE'必须声明

我的代码:

 DECLARE 
   f_payflag    VARCHAR2(25); --flag for test condition
   CURSOR cur_pledges IS
     SELECT idpledge, pledgeamt, paymonths, paydate, payamt, iddonor  
       FROM DD_PLEDGE JOIN DD_PAYMENT
            USING (IDPLEDGE)
      WHERE idpledge = 302
      ORDER BY idpledge, paydate;
 BEGIN
   FOR rec_iddonor IN cur_pledges LOOP
     IF cur_pledges%ROWCOUNT = 1 
     THEN 
       f_payflag :='First Payment';
     ELSE 
       f_payflag := NULL;
     END IF;
   END LOOP;

   DBMS_OUTPUT.PUT_LINE('Pledge ID: ' || idpledge || 
                        ' Pledge Amount: $' || pledgeamt || 
                        'Monthly Payment: $'|| paymonths ||
                        'Pay Date: ' ||  paydate || 
                        ' Amount Paid: $' || payamt ||
                        ' ' || f_payflag);    

 END;

1 个答案:

答案 0 :(得分:2)

首先,格式化代码非常有用。如果你一直在缩进,你会发现很多错误都会突然冒出来。

在这种情况下,第一个错误是你的dbms_output.put_line调用在循环结束后发生。这没有意义。假设您正在尝试为光标中返回的每一行写一行输出,那么您希望dbms_output调用在循环内。

第二个错误是您在dbms_output电话中尝试引用的所有变量都不存在。例如,没有局部变量idpledgepledgeamt。我的猜测是你打算引用rec_iddonor伪记录中的值。由于该伪记录仅存在于循环中,这往往支持我想要从循环内部打印值。然后,在引用字段时,您需要明确使用伪记录。

我的猜测是你需要像

这样的东西
 DECLARE 
   f_payflag    VARCHAR2(25); --flag for test condition
   CURSOR cur_pledges IS
     SELECT idpledge, pledgeamt, paymonths, paydate, payamt, iddonor  
       FROM DD_PLEDGE JOIN DD_PAYMENT
            USING (IDPLEDGE)
      WHERE idpledge = 302
      ORDER BY idpledge, paydate;
 BEGIN
   FOR rec_iddonor IN cur_pledges LOOP
     IF cur_pledges%ROWCOUNT = 1 
     THEN 
       f_payflag :='First Payment';
     ELSE 
       f_payflag := NULL;
     END IF;

     DBMS_OUTPUT.PUT_LINE('Pledge ID: ' || rec_iddonor.idpledge || 
                          ' Pledge Amount: $' || rec_iddonor.pledgeamt || 
                          ' Monthly Payment: $'|| rec_iddonor.paymonths ||
                          ' Pay Date: ' ||  rec_iddonor.paydate || 
                          ' Amount Paid: $' || rec_iddonor.payamt ||
                          ' ' || f_payflag);    

   END LOOP;

 END;