Oracle学习:PLSQL中的集合类型分析

  BTW,为了避免误解,以下显式提到“索引”的地方,并非指的是数据库表的索引,而是特指访问集合元素时使用的“下标”,即Collection_Name(index)中的index。

  与Associative array不同,Nested table变量需要显式初始化,其语法类似于C#,只是不用new关键字。额外地,Nested table初始化之后还需要调用EXTEND过程,扩展此集合的“容量”。

  示例的第二部分提供了一种相对简单的初始化方法,即可以在构造器中直接传入集合成员。这种简便的初始化方法不适用于Associative array

  最后我们来看VARRAY的声明及初始化,它与Nested table比较类似,但仍然存在一些区别,包括(1)VARRAY可以在声明时限制集合的长度,EXTEND的长度不能大于集合声明时的长度(下例中长度是8),但是在给集合成员赋值时,以EXTEND为准,例如下例中可以使用的只有3个集合成员。;(2)其索引总是连续的,而Nested table的索引在初始化赋值时是连续的,不过随着集合元素被删除,可能变得不连续。

  通常来说,对集合类型的第一选择应该是Associative array,因为它不需要初始化或者EXTEND操作,并且是迄今为止最高效的集合类型。唯一不足的一点是它只能用于PL/SQL而不能直接用于数据库。

  如果你需要使用10g,11g中的那些集合操作,应该选择Nested table;

  一个非常令人费解的地方是,位于PL/SQL语句块中的TYPE声明,必须使用关键字IS,而不能使用AS,但是在使用CREATE TYPE声明全局类型时,这两个是通用的。

  本来,说到这里就应该介绍完了,但是,Oracle引入了OO,导致我还要稍微说一下Object的声明及初始化,因为在某些情况下,你还会遇到集合成员是对象类型的情况。

  这样的语法会导致出现{PLS-00306: 调用 lang 时参数个数或类型错误},即Object类型没有默认的无参构造器。介绍完这个,那么即使集合的成员是Object时,也可以如法炮制去声明、初始化了。

TAG标签: sql学习
Ctrl+D 将本页面保存为书签,全面了解最新资讯,方便快捷。