ORACLE PL/SQL 集合学习笔记(二)

三、嵌套表的使用方法

 

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约束在这种情形下就像一个数据库的引用完整性约束一样,因此也是不允许的。

 

1INSERT

像前面介绍的VARRAYS一样,插入语句只有一种访问方式。它是以要么全有要么全无的方式访问数据类型的。

如下例所示:

 

 

同样,如果我们通过如下所示的普通的SELECT语句来对插入的嵌套表类型列进行查询,会返回带有实际参数的构造函数的返回值集合,得到的结果并不是我们想要的。

 

  

 

我们可以使用下面的语句来对嵌套表类型列进行查询。

 

 

  

 

 

2UPDATE

前面我们已经看到,如果不改变整个VARRAYS内容,那么PL/SQL是唯一的一种更新VARRAYS的方法,但是PL/SQL不是唯一的一种更新嵌套表的方法。嵌套表的优点就是我们可以更新各个行元素,这些更新可以直接通过DML的更新语句实现。

使用下面的示例程序可以替换嵌套表数据类型列STREET_ADDRESS的全部内容:

 

  

 

也可以直接在SQL中更新嵌套表列的部分值,下面这个示例程序更新了嵌套表STREET_ADDRESS的第一行记录。

 

 

 

另外,还可以使用PL/SQL实现这种更新操作。在PL/SQL中,可以使用下面这两种方法:

  • 直接更新嵌套表的某一行记录
  • 为某个嵌套表列而更新这一行的所有内容

更新某一行记录全部内容的方法类似前面对VARRAYS使用的那种方法,这里就不再重复。下面介绍怎样直接在嵌套表列中直接更新嵌套表的某一行记录。下面这个示例使用了动态SQL技术和绑定变量技术。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值