先来看看内表是什么东西。顾名思义内表是一张存在内存中的表。首先,它是由很多work
area组成。所谓work
area,说通俗一点即是表的一行,占用一定的内存空间。那么为什么要有内表存在呢?原因在于我们直接在数据库中取数速度慢,而内存的速度远远高于存储数据的硬盘的速度,我们将数据库表拷贝至存在于内存中的内表上,再在内表上进行查询、取数等操作,效率将大大提高。这也是近些年SAP大力推销其内存计算产品的一个原因。
先看一段关于内表的小程序:
DATA: BEGIN OF LINE,
DATA: BEGIN OF LINE OCCURS 0,
前者声明了一个work area,后者则声明了一个internal table。
对比这两段程序,可以看出二者的区别就在于一个包含OCCURS,而另一个不包含。OCCURS的意思是为这个内表分配多大的空间,可以简单的理解为为内表分配了若干行的空间。第一个程序没有使用occurs,所以它是一个workarea,我们可以简单的理解成它是内表的一行,因为内表是由若干个work area组成的。实际上我们可以先定义一行的workarea然后通过APPEND行的方式,来实现内表的定义,因此occurs现在就并不常用了。
内表与工作区在语法上有所区分,但在实际上可以理解为相近的东西,即内表是由工作区组成的。
内表操作对应的关键字有type table of, type lineof等,而单独使用type则是对于工作区而言。
再看一段关于内表声明的小程序:
DATA: BEGIN OF LINE OCCURS 0,
TYPES: BEGIN OF LINE,
DATA: ITAB TYPE TABLE OF LINE.
这边说明了DATA与TYPES的区别,因为这种区别导致了内表不同的声明方法。DATA声明的东西对应于c语言中的初始化变量,是已经分配了内存空间的了。而type声明的东西相当于一种变量类型,对应于c语言中的结构体,需要为它赋值、初始化。