转自:http://blog.csdn.net/johnnydev/article/details/7530362
看到同事写的存储过程里面有这样一句:
TYPE ARRAY_TYPE IS VARRAY(10000) OF VARCHAR2(60);
感到很茫然,幸好还有网络可以求助,我理解成是:长度为10000的数组,其每个为长度为最大长度为60的varchar2类型。不知是否准确?
1. 声明和初始化VARRAY变量
你不可以直接声明一个VARRAY变量。必须先声明一个包含这个数组最大容量的类型:
- TYPE MY_ARRAY_TYPE IS VARRAY(10) OF NUMBER;
然后,你就可以用这个类型声明VARRAY变量:
- V MY_ARRAY_TYPE;
在你对这个数组进行操作以前,必须先初始化该数组。你既可以在声明它的时候对其初始化,也可以在声明后对其赋值。下面展示了在声明的同时对其进行初始化:
- V MY_ARRAY_TYPE := MY_ARRAY_TYPE ();
2. 从指定的条目处取值
把条目的数目作为下标。下标可以是返回整数值(该值小于或等于数组条目数)的任意表达式,如:
- K := V(3);
- I := 2;
- L := V(I+1);
3. 得到数组的容量
对VARRAY变量使用COUNT()方法。注意,你不需要指定圆括号,因为这个方法没有输入参数:
- N_ENTRIES := V.COUNT();
这告诉你这个数组中正在使用的条目数。当VARRAY类型被声明的时候,其最大的容量也就被定义了。你可以用LIMIT()方法得到该容量:
- ARRAY_CAPACITY := V.LIMIT();
4. 遍历VARRAY中的值
你可以使用多种技术。最简单的是使用FOR循环:
- FOR I IN 1..V.COUNT() LOOP
- DBMS_OUTPUT.PUT_LINE('V('||I||')=' || V(I));
- END LOOP;
你也可以使用FIRST()和LAST()方法。FIRST()返回数组的第一个条目的下标(总是1),LAST()返回数组的最后一个条目的下标(与COUNT方法相同)。
- FOR I IN V.FIRST()..V.LAST() LOOP
- DBMS_OUTPUT.PUT_LINE('V('||I||')=' || V(I));
- END LOOP;
你也可以使用PRIOR(n)和NEXT(n)方法,这两个方法分别返回给定条目的前一个和后一个条目的下标。例如,下面的代码用来向后遍历整个数组:
- I := V.COUNT();
- WHILE I IS NOT NULL LOOP
- DBMS_OUTPUT.PUT_LINE('V('||I||')=' || V(I));
- I := V.PRIOR(I);
- END LOOP;
PRIOR(n)和n-1是一样的,NEXT(n)和n+1是一样的,但是PRIOR(1)和NEXT (V.COUNT())则返回NULL。
5. 对VARRAY的扩展
使用EXTEND(k)方法。这个方法可以在VARRAY的最后追加k个新的条目。如果k没有被指定,只增加一个条目。新增的条目没有值(默认为NULL),但是你可以对它们进行初始化。COUNT()和LAST()方法现在可以反映VARRAY新的容量。以下代码向数组中添加两个条目并对其进行初始化:
- I := V.LAST();
- V.EXTEND(2);
- V(I+1) := 5;
- V(I+2) := 6;
注意,你对VARRAY的扩展不可以超过其最大容量(通过LIMIT()方法得到),且在对VARRAY扩展前必须要对其进行初始化。以下代码是无效的:
- VT MY_ARRAY_TYPE;
- VT.EXTEND(5);
下面的代码是有效的:
- VT MY_ARRAY_TYPE;
- VT := MY_ARRAY_TYPE();
- VT.EXTEND(5);
6. 对VARRAY的缩减
使用TRIM(k)方法。这个方法在VARRAY的尾部删除最后k个条目。当k没有被指定时,删除最后一个条目。已被删除的条目的值将丢失。COUNT()和LAST()方法反映了新的容量。下面从VARRAY中删除最后一个条目:
- V.TRIM;
你也可以用以下方式删除数组中的所有条目:
- V.TRIM(V.COUNT());
或者用具有效果相同的DELETE()方法。该方法删除数组中的所有条目,并把其容量设置为0(也就是说,V.COUNT()现在的返回值为0)。
- V.DELETE()