学习笔记(十一)

标准表,关键字为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.
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值