ABAP 内表-标题行-工作区简介

ABAP 内表(internal table) 标题行(header line) 工作区(work area) 简介

1. Difference between Work Area and Header Line

在对内表进行一些操作的时候,比如增加或者取回一条记录.我们必须暂时保存这条记录.
这条记录就保存在内表的工作区里(work area).内表的工作区必须和内表有相同的结构.
内表由主体(body)和一个可选的标题行(head line)组成.
标题行是一个隐式的(implicit)工作区.在内表声明的时候,可以选择有无标题行.
e.g.
data: begin of itab occurs 10,
        ab type c,
        cd type i,
      end of itab.
这样的内表itab,是有标题行的.
data: wa_itab like itab.
这样的wa_itab是显式(explicit)声明的一个itab的工作区.
data: itab1 like itab occurs 10.
这样的内表itab1,是没有标题行的.

标题行是一个和内表主体有着一样结构的字段的串,标题行只有一行.
所以,标题行相当于一个缓冲区(buffer),用于存放被操作的纪录,是内表的缺省的工作区.

2. Using Header Lines as Work Areas

当你在创建一个内表的时候,你同时也声明了一个具有相同名称的标题行(这个好像很奇特的样子么...).可以把这个标题行当作工作区来对内表进行操作.
如果一个内表有标题行,则对其进行操作的ABAP语句会简短一些,因为这些语句会自动认为标题行是一个隐式的工作区.语句的不同如下表:

Operations without header line

Operations with header line

Operations for all Table Types

INSERT INTO TABLE .

INSERT TABLE ITAB.

COLLECT INTO .

COLLECT .

READ TABLE ... INTO .

READ TABLE ...

MODIFY TABLE FROM ...

MODIFY TABLE ...

MODIFY FROM ...WHERE ...

MODIFY ... WHERE ...

DELETE TABLE FROM .

DELETE TABLE .

LOOP AT ITAB INTO ...

LOOP AT ITAB ...

Operations for Index Tables

APPEND TO .

APPEND .

INSERT INTO ...

INSERT ...

MODIFY FROM ...

MODIFY ...

但是,用隐式的工作区,代码难以被理解,所以还是用一个不同名称的工作区比较好.

刚开始学ABAP的时候,学到iternal table,感觉一阵混乱.
搞不清楚什么是work area,什么是header line,以及occurs是干什么用的.
今天终于差不多搞明白了(我还是太弱啊...BS自己一下)
所以还是记录下来..省得自己以后再忘记...

先是用TYPES关键字定义一个行(row)的类型.如下:
TYPES: BEGIN OF line,
field1 TYPE i,
field2 TYPE i,
END OF line.

 

 

 

有一下两种方式操作itab:
1).
wa-field1 = 1.
wa-field2 = 2.
APPEND wa TO itab.
2).
itab-field1 = 1.
itab-field2 = 2.
APPEND itab.
这里wa就是上面那个已经定义的work area.
header line的时候,这两种都可以.
header line的时候,只能用第1.
2种里,itab的意义是一个header line,而不是内表.
因为"DATA itab TYPE line OCCURS 0 WITH HEADER LINE."这样的声明,
已经隐式声明了一个与内表同名的header line.
所以OCCURS用来声明内表可能造成二义性(ambiguous).
于是,OCCURS被认为是old的东西,采用一下方式声明一个内表比较好:
DATA itab TYPE STANDARD TABLE OF line.

还有一种声明内表的方法:
DATA: BEGIN OF itab OCCURS 0,
              field1 TYPE i,
              field2 TYPE i,
           END OF itab.
这样的itab就自动有了一个同名的header line.
好像不会有 WITHOUT HEADER LINE 或者 NOT WITH HEADER LINE 这样的用法...
如果没有OCCURS 0,比如这样:
DATA: BEGIN OF itab,
              field1 TYPE i,
              field2 TYPE i,
         END OF itab.
那么这个itab就不是内表咯,只是一个structure,可以作为itabwork area.

写到这里发现,归根到底就是TYPESDATA这两个关键字的区别嘛.
还有有无OCCURS的区别.

posted @ 2011-08-21 23:27  VerySky  阅读(483)  评论(0)    收藏  举报