集合(VarRays和嵌套表)
Oracle 9i支持三种集合数据类型:index-by 表,Varrays(可变数组)和嵌套表
Varrays 由其元素的最大数目限定的单维有限数组,可以改变varrays数组的上界.可以使用varrays按一定顺序存储固定数目的元素.元素插入到Varrays数组时,是从位置1开始的,可以一直增加到数组长度的上限,varrays元素的最大数目为2G
1、定义VARRAY类型
Type type_name is {varray|varraying array}(max size) of data_type [not null]
下面是一个定义例子:
type num_varray is varray(5) if number;
在指定data_type时,以专守以下规则:
可以使用%TYPE和%ROWTYPE
data_type不能是BOOLEAN、NCHAR、NVARCHAR2、REF CURSOR、NCLOB类型
下面是一个可变数组的例程
procedure
varrays_demo
is
num_varray num_varray_type;
begin
num_varray: = num_varray_type( 1 , 2 , 3 , 4 , 5 , 6 , 7 , 8 , 9 , 10 );
dbms_output.put_line(num_varray( 1 ));
for idx in 1 .. 10 loop
dbms_output.put_line(num_varray(idx));
end loop;
if num_varray is null then
dbms_output.put_line( ' num_varray is null ' );
else
dbms_output.put_line( ' num_varray is not null ' );
end if ;
end varrays_demo;
end test;
is
num_varray num_varray_type;
begin
num_varray: = num_varray_type( 1 , 2 , 3 , 4 , 5 , 6 , 7 , 8 , 9 , 10 );
dbms_output.put_line(num_varray( 1 ));
for idx in 1 .. 10 loop
dbms_output.put_line(num_varray(idx));
end loop;
if num_varray is null then
dbms_output.put_line( ' num_varray is null ' );
else
dbms_output.put_line( ' num_varray is not null ' );
end if ;
end varrays_demo;
end test;
嵌套表
嵌套表是数据元素可以无限大而且无序的一个一维数据,所有元素的数据类型都相同。除了定义它时不能使用index by binary_integer子句外,与index-by表非常相似,嵌套表数组中没有最大数目限制。(实际上也是一个一维数组)。
1、定义TABLE类型
其语法如下
type table_name is table of data_type [not null]
如:
type num_table is table of number
该语句声明了一个元素数目无限大的数字型嵌套表
定义data_type时,要专守以下规划:
A、可以使用%TYPE和%ROWTYPE
B、可以是另一个oracle 9i的varray或table类型
C、不能是BOOLEAN、NCHAR、NVARCHAR2、NCLOB、REF CURSOR类型,下面是一个例程:
procedure
table_demo
is
type num_table is table of number ;
v_numtable num_table;
vcount number ;
begin
if v_numtable is null then
dbms_output.put_line( ' v_numtable is null ' );
end if ;
v_numtable : = num_table(); -- 不带参数构造一个空表
if v_numtable is null then
dbms_output.put_line( ' 构造一个空v_numtable is null ' );
else
dbms_output.put_line( ' 构造一个空表时,v_numtable 不等于null ' );
end if ;
-- if v_numtable(1) is null then --这样的话,编译虽通过,执行时出错
-- dbms_output.put_line('a');
-- end if;
v_numtable: = num_table( 1 , 2 , 50 , 20 );
vcount: = v_numtable. count ();
for idx in 1 ..vcount loop
dbms_output.put_line(v_numtable(idx));
end loop;
end table_demo;
end test;
is
type num_table is table of number ;
v_numtable num_table;
vcount number ;
begin
if v_numtable is null then
dbms_output.put_line( ' v_numtable is null ' );
end if ;
v_numtable : = num_table(); -- 不带参数构造一个空表
if v_numtable is null then
dbms_output.put_line( ' 构造一个空v_numtable is null ' );
else
dbms_output.put_line( ' 构造一个空表时,v_numtable 不等于null ' );
end if ;
-- if v_numtable(1) is null then --这样的话,编译虽通过,执行时出错
-- dbms_output.put_line('a');
-- end if;
v_numtable: = num_table( 1 , 2 , 50 , 20 );
vcount: = v_numtable. count ();
for idx in 1 ..vcount loop
dbms_output.put_line(v_numtable(idx));
end loop;
end table_demo;
end test;
集合方法
pl/sql预定义了在varray 和嵌套表实例上进行调用的方法。这些方法能在集合上执行一定的功能。
EXISTS |
该函数返回集合中第一个元素的索引,如果集合为空,返回NULL |
Collection.EXISTS(index) |
COUNT |
该函数集合元素的数目 |
Collection.COUNT |
DELETE |
该过程从嵌套表中删除一个或多个或合部元素 |
Table_name.DELETE 删除所有元素 Table_name.delete(index)删除指定索引的记录 Table_name.delete(start_index,end_index)删除区间内元素 |
FIRST |
返回集合第一个元素索引,如果集合为空,返回NULL |
Collection.FIRST |
LAST |
返回集合中最后一个元素索引,如果集合为空,返回NULL |
Collection. LAST |
NEXT |
返回集合当前元素的下一个元素的索引,如果它不存在就返回NULL |
Collection. NEXT |
PRIOR |
返回集合当前元素的上一个元素的索引,如果它不存在就返回NULL |
Collection. PRIOR |
LIMIT |
返回varray中创建元素的最大个数 |
Collection. LIMIT |
EXTENDS |
该过程在集合的末尾添加新的元素 |
Collection.EXTEND添加一个NULL元素;Collection.extends(n)添加N个NULL元素,Collection.extend(n,index)添加由index指定位置上元素的n个副表 |
TRIM |
从集合末尾处删除元素 |
Collection.TRIM 删除最后一个元素 Collection.TRIM(n)删除最后N个元素 |
数据加中的集合
与index-by表不同,varray和嵌套表可以作为对象-关系表中的珍存储在数据库中。它们也可以作为对象关系表中的列使用。为了表示出作为数据库列的数据类型,集合类型必须是在pl/sql和sql中可见。这需要使用create or replace type 语句定义而不能仅在pl/sql块中进行局部定义。语法如下:
create of replace type table_name is table of data_type