ABAP 7.4新特性(一):行内定义 Inline Declarations详解编程语言

发现个坑,比如  SELECT SINGLE *
    INTO @DATA(WA_WMJXRW)
    FROM ZTA_WMJXRW
    WHERE ZJXDH = @RLMOB-ZJXDH.  当这段代码在一个循环或者重复执行function里的话,如果第一次成功出数据,

第二次没有找到数据的话用IF WA_WMJXRW IS INITIAL判断会为假!!!! 还是用sy-subrc判断吧

以前我们要用一个变量的时候,需要在使用语句的前面先定义。现在,可以在使用的时候就定义了。

比如说我们经常要预先定义表的工作区,然后在loop时使用。现在可以在loop的时候就定义对于表的工作区了。

以前:

DATA itab TYPE TABLE OF scarr.
SELECT * FROM scarr into TABLE itab.
DATA wa LIKE LINE OF itab.
READ TABLE itab WITH KEY carrid = ‘LH’ INTO wa. 
现在:
DATA itab TYPE TABLE OF scarr.
SELECT * FROM scarr into TABLE itab.
READ TABLE itab WITH KEY carrid = ‘LH’ INTO DATA(wa). “行内定义(inline declaration)变量
LOOP AT同理,注意行内定义的变量作用域和以前定义的是一样的。
又比如在方法中接收返回变量时:

原:

    DATA a1 TYPE…..
    DATA a2 TYPE…
    oref->meth( IMPORTING p1=a1
              IMPORTING p1=a2
            …. )
现在:

    oref->meth( IMPORTING p1 = DATA(a1)
              IMPORTING p1=  DATA(a2)
            …. )
对于field symbols也是支持行内定义的。

以前1: 

DATA a TYPE string VALUE ‘test’.
FIELD-SYMBOL <fs>.
ASSIGN  a to <fs>.
        现在:

DATA a TYPE string VALUE ‘test’.
ASSIGN  a to FIELD-SYMBOL(<fs>).
还可以用在读取内表中:
LOOP AT itab ASSIGNING FIELD-SYMBOL(<line>) where carrid = ‘LH’. “

   WRITE:<line>.

ENDLOOP.

READ TABLE itab assigning field-symbol(<line2>) INDEX 1.
行内定义方便了我们的使用,在内表中它会自动根据读取的内表类型定义相应的工作区类型。但是使用这种方法注意作用域问题。
 

原创文章,作者:Maggie-Hunter,如若转载,请注明出处:https://blog.ytso.com/20215.html

(0)
上一篇 2021年7月19日
下一篇 2021年7月19日

相关推荐

发表回复

登录后才能评论