首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >RPGLE条目列表向字符串变量中添加前导空格

RPGLE条目列表向字符串变量中添加前导空格
EN

Stack Overflow用户
提问于 2018-08-03 14:39:34
回答 1查看 494关注 0票数 1

我正在测试一个新程序,它将参数从CL传递给SQLRPGLE。

我总共声明了16个变量,并使用CHGVAR来设置值来测试参数的传递。

代码语言:javascript
复制
         PGM

         DCL        VAR(&COMPFR) TYPE(*CHAR) LEN(3)
         DCL        VAR(&COMPTO) TYPE(*CHAR) LEN(3)
         DCL        VAR(&LOCFR) TYPE(*CHAR) LEN(4)
         DCL        VAR(&LOCTO) TYPE(*CHAR) LEN(4)
         DCL        VAR(&CLSTFR) TYPE(*CHAR) LEN(1)
         DCL        VAR(&CLSTTO) TYPE(*CHAR) LEN(1)
         DCL        VAR(&CUSTFR) TYPE(*CHAR) LEN(7)
         DCL        VAR(&CUSTTO) TYPE(*CHAR) LEN(7)
         DCL        VAR(&ITEMFR) TYPE(*CHAR) LEN(20)
         DCL        VAR(&ITEMTO) TYPE(*CHAR) LEN(20)
         DCL        VAR(&CLDTFR) TYPE(*CHAR) LEN(8)
         DCL        VAR(&CLDTTO) TYPE(*CHAR) LEN(8)
         DCL        VAR(&SCDTFR) TYPE(*CHAR) LEN(8)
         DCL        VAR(&SCDTTO) TYPE(*CHAR) LEN(8)
         DCL        VAR(&CMDTFR) TYPE(*CHAR) LEN(8)
         DCL        VAR(&CMDTTO) TYPE(*CHAR) LEN(8)

         CHGVAR     VAR(&COMPFR) VALUE('2')
         CHGVAR     VAR(&COMPTO) VALUE('2')
         CHGVAR     VAR(&LOCFR) VALUE('6')
         CHGVAR     VAR(&LOCTO) VALUE('6')
         CHGVAR     VAR(&CLSTFR) VALUE('0')
         CHGVAR     VAR(&CLSTTO) VALUE('9')
         CHGVAR     VAR(&CUSTFR) VALUE('0000000')
         CHGVAR     VAR(&CUSTTO) VALUE('9999999')
         CHGVAR     VAR(&ITEMFR) VALUE('00000000000000000000')
         CHGVAR     VAR(&ITEMTO) VALUE('99999999999999999999')
         CHGVAR     VAR(&CLDTFR) VALUE('00000000')
         CHGVAR     VAR(&CLDTTO) VALUE('99999999')
         CHGVAR     VAR(&SCDTFR) VALUE('00000000')
         CHGVAR     VAR(&SCDTTO) VALUE('99999999')
         CHGVAR     VAR(&CMDTFR) VALUE('00000000')
         CHGVAR     VAR(&CMDTTO) VALUE('99999999')

         CALL       PGM(JALLIB/SBRNTRPT) +
                     PARM(&COMPFR &COMPTO +
                     &LOCFR &LOCTO &CLSTFR &CLSTTO +
                     &CUSTFR &CUSTTO &ITEMFR &ITEMTO +
                     &CLDTFR &CLDTTO &SCDTFR &SCDTTO +
                     &CMDTFR &CMDTTO)


         ENDPGM

然后接受RPGLE中的参数,并相应地构建SQL语句。下面的片段显示了我如何接受参数

代码语言:javascript
复制
// Qualfied parameters data structure defined

    dcl-ds parmsds qualified;
      compfr char(3);
      compto char(3);
      locfr char(4);
      locto char(4);
      clstfr char(1);
      clstto char(1);
      custfr char(7);
      custto char(7);
      itemfr char(20);
      itemto char(20);
      cldtfr char(8);
      cldtto char(8);
      scdtfr char(8);
      scdtto char(8);
      cmdtfr char(8);
      cmdtto char(8);
    end-ds;

    // Prototype and Interface used to pass parmeters from the CL Program

    dcl-pr sbrntrpt extpgm;
      parms likeds(parmsds);
    end-pr;

    dcl-pi sbrntrpt;
      parms likeds(parmsds);
    end-pi;

但出于某种原因,当我调试和检查parms列表时。一个变量itemfr正在向变量中添加两个前导空格,并在该变量后面抛出其余的输入。

我使用了SNDPGMMSG来验证从CL发送的值是否准确,但是当我接受这个大字符串时,有些地方出了问题。我甚至试图使字符串2字符更长,但之后的变量ITEMTO,得到10个前导空格。

到目前为止,这个程序非常简单,所以我不知道是什么原因造成了这种情况。如有任何指导,将不胜感激。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2018-08-03 15:10:35

所以你要做的是把16个参数传递给一个程序,并接收一个参数。它可能在今天工作,明天就会失败,这取决于内存中16个参数的排列方式。如果要传递16个参数,则确实需要接收16个参数。解决这个问题的方法有两种: 1)在RPG程序中添加每个字段作为参数,或者2)将CL程序中的字段组合成一个单一的结构。

在RPG中接收多个参数:

代码语言:javascript
复制
dcl-pr sbrntrpt extpgm;
  compfr     Char(3);
  compto     Char(3);
  ...
  cmdtto     Char(8);
end-pr;

dcl-pi sbrntrpt;
  compfr     Char(3);
  compto     Char(3);
  ...
  cmdtto     Char(8);
end-pi;

-或者-

从中电通过一个结构

代码语言:javascript
复制
PGM

DCL        VAR(&PARMS)  TYPE(*CHAR) LEN(118)
DCL        VAR(&COMPFR) TYPE(*CHAR) LEN( 3) STG(*DEFINED) DEFVAR(&PARMS   1)
DCL        VAR(&COMPTO) TYPE(*CHAR) LEN( 3) STG(*DEFINED) DEFVAR(&PARMS   4) 
DCL        VAR(&LOCFR)  TYPE(*CHAR) LEN( 4) STG(*DEFINED) DEFVAR(&PARMS   7) 
DCL        VAR(&LOCTO)  TYPE(*CHAR) LEN( 4) STG(*DEFINED) DEFVAR(&PARMS  11) 
DCL        VAR(&CLSTFR) TYPE(*CHAR) LEN( 1) STG(*DEFINED) DEFVAR(&PARMS  15) 
DCL        VAR(&CLSTTO) TYPE(*CHAR) LEN( 1) STG(*DEFINED) DEFVAR(&PARMS  16) 
DCL        VAR(&CUSTFR) TYPE(*CHAR) LEN( 7) STG(*DEFINED) DEFVAR(&PARMS  17) 
DCL        VAR(&CUSTTO) TYPE(*CHAR) LEN( 7) STG(*DEFINED) DEFVAR(&PARMS  24) 
DCL        VAR(&ITEMFR) TYPE(*CHAR) LEN(20) STG(*DEFINED) DEFVAR(&PARMS  31) 
DCL        VAR(&ITEMTO) TYPE(*CHAR) LEN(20) STG(*DEFINED) DEFVAR(&PARMS  51) 
DCL        VAR(&CLDTFR) TYPE(*CHAR) LEN( 8) STG(*DEFINED) DEFVAR(&PARMS  71) 
DCL        VAR(&CLDTTO) TYPE(*CHAR) LEN( 8) STG(*DEFINED) DEFVAR(&PARMS  79) 
DCL        VAR(&SCDTFR) TYPE(*CHAR) LEN( 8) STG(*DEFINED) DEFVAR(&PARMS  87) 
DCL        VAR(&SCDTTO) TYPE(*CHAR) LEN( 8) STG(*DEFINED) DEFVAR(&PARMS  95) 
DCL        VAR(&CMDTFR) TYPE(*CHAR) LEN( 8) STG(*DEFINED) DEFVAR(&PARMS 103)
DCL        VAR(&CMDTTO) TYPE(*CHAR) LEN( 8) STG(*DEFINED) DEFVAR(&PARMS 111)

CHGVAR     VAR(&COMPFR) VALUE('2')
CHGVAR     VAR(&COMPTO) VALUE('2')
CHGVAR     VAR(&LOCFR) VALUE('6')
CHGVAR     VAR(&LOCTO) VALUE('6')
CHGVAR     VAR(&CLSTFR) VALUE('0')
CHGVAR     VAR(&CLSTTO) VALUE('9')
CHGVAR     VAR(&CUSTFR) VALUE('0000000')
CHGVAR     VAR(&CUSTTO) VALUE('9999999')
CHGVAR     VAR(&ITEMFR) VALUE('00000000000000000000')
CHGVAR     VAR(&ITEMTO) VALUE('99999999999999999999')
CHGVAR     VAR(&CLDTFR) VALUE('00000000')
CHGVAR     VAR(&CLDTTO) VALUE('99999999')
CHGVAR     VAR(&SCDTFR) VALUE('00000000')
CHGVAR     VAR(&SCDTTO) VALUE('99999999')
CHGVAR     VAR(&CMDTFR) VALUE('00000000')
CHGVAR     VAR(&CMDTTO) VALUE('99999999')

CALL       PGM(JALLIB/SBRNTRPT) +
            PARM(&PARMS)


ENDPGM
票数 11
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/51675024

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档