标准表,关键字为STANDARD TABLE,系统为该表的每一行数据生成一个逻辑索引,填充时,可以将数据附加在现有行之后,也可是插入到指定的位置,程序对行的寻址操作可通过关键字或索引进行,进行插入、删除操作时,各行在内存中的位置不变,系统重新排列各行的索引值;
排序表,关键字为SORTED TABLE,也有一个逻辑索引,不同的是排序表总是按其表关键字升序排列后再存储,也通过关键字或索引访问;
哈希表,关键字为HASHED TABLE,没有索引,只能通过关键字访问,系统用哈希算法管理表中的数据,因此其寻址一行的时间与表的行数无关;
一般性表,即索引表INDEX TABLE 和任意表ANY TABLE,可以用于类型定义中,但不能用于声明一个内表对象,因为没有任何明确的表类型,系统无法确定其操作方式,可以用于指明字段符号和接口参数的类型,以增加这些元素的实用性,其实际类型可能在运行期内才能够确定;
行结构,内表的行可以是有任意类型的数据类型组成,大多数行类型是结构体或者是引用数据字典中的结构形成的,也有基本类型或引用类型的数组,行结构中还可以包含表类;
表关键字在访问内表和内表排序的过程中起重要作用,使用WITH KEY 指定表关键字,如果不指定关键字,系统使用默认(标准)关键字;
如果内表行结构是结构体,则可以指定结构体中的某几个字段作为内表关键字,该字段不能是内表或者引用类型,可以是嵌套结构体;
如果内表的整个行都是由基本类型字段组成的,则可以把内表整行指定为表关键字,如果内表字段是结构化类型,则不应指定整行作为关键字段;
WITH [UNIQUE | NON-UNIQUE] KEY com1
WITH [UNIQUE | NON-UNIQUE] KEY TABLE LINE
WITH [UNIQUE | NON-UNIQUE] DEFAULT KEY
扁平结构内表的默认表关键字是非数字和非内表的组件字段,如果内表的行是个单个基本类型组成,则默认关键字为整行,如果内表行中包含有内表类型字段,则没有默认关键字段;
标准表不能用UNIQUE关键字,也无需指明NON-UNIQUE,排序表可以用UNIQUE或NON-UNIQUE,哈希表不能用NON-UNIQUE,必须指明UNIQUE;
TYPES: BEGIN OF address,
street(20) TYPE c,
city(20) TYPE c,
END OF address.
DATA: BEGIN OF company,
name(20) TYPE c,
addresses TYPE address,
END OF company.
DATA table_company LIKE HASHED TABLE OF company WITH UNIQUE KEY name.
DATA table_company_sorted LIKE SORTED TABLE OF company WITH UNIQUE KEY name.