三、嵌套表的使用方法
1、将嵌套表定义为PL/SQL的程序构造块
TYPE type_name IS TABLE OF element_type[NOT NULL];
如下例所示:
2、将嵌套表类型定义和用作PL/SQL的对象类型
CREATE OR REPLACE TYPE type_name
AS TABLE OF element_type [NOT NULL];
如下例所示:
3、将嵌套表定义和用作表的列数据类型
在ORACLE 10G中,VARRAYS是以内联结构的形式存储的,并允许NOT NULL约束。相对而言,如果将嵌套表作为数据表的列,就不允许使用NOT NULL约束。
在嵌套表列上定义NOT NULL约束,相当于在定义嵌套表以前,管理插入到其中的记录行。而这是不可能的。NOT NULL约束在这种情形下就像一个数据库的引用完整性约束一样,因此也是不允许的。
1)INSERT
像前面介绍的VARRAYS一样,插入语句只有一种访问方式。它是以要么全有要么全无的方式访问数据类型的。
如下例所示:
同样,如果我们通过如下所示的普通的SELECT语句来对插入的嵌套表类型列进行查询,会返回带有实际参数的构造函数的返回值集合,得到的结果并不是我们想要的。
我们可以使用下面的语句来对嵌套表类型列进行查询。
2)UPDATE
前面我们已经看到,如果不改变整个VARRAYS内容,那么PL/SQL是唯一的一种更新VARRAYS的方法,但是PL/SQL不是唯一的一种更新嵌套表的方法。嵌套表的优点就是我们可以更新各个行元素,这些更新可以直接通过DML的更新语句实现。
使用下面的示例程序可以替换嵌套表数据类型列STREET_ADDRESS的全部内容:
也可以直接在SQL中更新嵌套表列的部分值,下面这个示例程序更新了嵌套表STREET_ADDRESS的第一行记录。
另外,还可以使用PL/SQL实现这种更新操作。在PL/SQL中,可以使用下面这两种方法:
-
直接更新嵌套表的某一行记录
-
为某个嵌套表列而更新这一行的所有内容
更新某一行记录全部内容的方法类似前面对VARRAYS使用的那种方法,这里就不再重复。下面介绍怎样直接在嵌套表列中直接更新嵌套表的某一行记录。下面这个示例使用了动态SQL技术和绑定变量技术。