abap内表,标题行,工作区

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

这里的line, 就相当于一个自定义 的类型 , 表示一行(row) 的字段(field).
这里一行有两个字段field1 和field2.

然后是声明一个work area:
DATA wa TYPE line.
运用面向对象的概念理解就是,
line 是一个class, 而wa 是一个object.

 

接着是声明一个每一行的类型是line 的internal table:
DATA itab TYPE line OCCURS 0.
我在暂时把OCCURS 作为了区别工作区和内表的标志 .
OCCURS 应该有更深层次的意义, 但我目前只能领悟至此...
当我们用以上这个方法来声明一个iternal table 时, 可以选择是否有无header line.
上面这句就是没有header line 的. 改成如下就有了:
DATA itab TYPE line OCCURS 0 WITH HEADER LINE.
有无header line 的区别就是,header line 可以当作一个work area 来使用 .
有一下两种方式操作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 的区别

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值