RPG exec sql只能运行一次

时间:2017-08-18 13:40:22

标签: sql ibm-midrange rpgle

我用RPG IV自由格式编写程序,我遇到了一个问题。我试图用:

执行sql语句
dcl-proc getRecord;
dcl-pi *N int(5) end-pi;
dcl-s rec int(5) inz(0);

exec sql
select max(SCORE) into :rec from SNK_HISC;

return rec;
END-PROC;   

编译后只能运行一次。也许我应该重置一些指标或sql标志?在程序结束时我使用:

*inlr = *on;
return;    

调用程序的地方:

   exfmt BACK;
   exfmt INFO;

   inital();


   dow run and alive;
     write MAINBOARD;
     READ(E) AKE_DSP;
     run = FKeyListener();
     alive = goForward();
   ENDDO;
   LSCORE = points;
   if points > getRecord();
     LRECORD = 'NEW RECORD!';

     exec sql
       insert into AKE_HISC( USID , SCORE) VALUES( :userID , :points);

   ENDIF;
   exfmt ENDING;


   *inlr = *on;
   return; 

在此程序中:

dcl-proc inital;
     snake(1).x = 5;
     snake(2).x = 5;
     snake(3).x = 5;
     snake(1).y = 5;
     snake(2).y = 6;
     snake(3).y = 7;
     direction.x = 1;
     direction.y = 0;
     SCORE = points;
     RECORD = getRecord();
     genSnack();
     refresh();
   END-PROC;

我使用这个CL程序运行程序:

         PGM

         MONMSG     MSGID(CPF0000 MCH0000) EXEC(GOTO CMDLBL(END))

         OVRDSPF    FILE(AKE_DSP) DEV(*REQUESTER) WAITRCD(1)

         CALL       PGM(AKE_S)

 END:    
         DLTOVR     FILE(*ALL)
         MONMSG     MSGID(CPF0000)

         ENDPGM

1 个答案:

答案 0 :(得分:0)

问题不在于sql查询,而在于它的位置。我删除了程序getRecord()并创建了rec全局变量,并且sql查询被放置在主周期内。这就是所有。