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,可以作为itab的work area.
写到这里发现,归根到底就是TYPES和DATA这两个关键字的区别嘛.
还有有无OCCURS的区别.

浙公网安备 33010602011771号