_Oracle数据库_黑客防线网安服务器维护基地--Powered by WWW.RONGSEN.COM.CN

Oracle10g里面新地多重集运算符解释分析

作者:黑客防线网安Oracle维护基地 来源:黑客防线网安Oracle维护基地 浏览次数:0

Oracle 10g 中针对 SQL Server 2003 新添加了一系列支持 Advanced Multiset 的运算符他们可以用于对 Oracle 数据库中的嵌套表进行处理这个SQL 新语法具有强大的功能并弥补了 Oracle 8i中对于嵌套表的不足之处但是用户手册中给出的相关例子非常复杂,很难了解到这些新函数的使用方法。

下面举个非常简单的例子来说明一下,假设我们要使用一个记录了整型数据的嵌套表。在创建嵌套表时,首先必须为将要创建的表指定一个表名,这个表将用来存放嵌套表的数据。 create or replace type num_tab_typ as table of number;/create table num_tab (num num_tab_typ)nested table num store as num_tab_store;

然后往表中插入一些数列,这些数列分别为从1到5的数字,以及一些奇数数字和偶数数字。然后对其进行查询:

insert into num_tab values (num_tab_typ(1,2,3,4,5));insert into num_tab values (num_tab_typ(1,3,5));insert into num_tab values (num_tab_typ(2,4,6));select num from num_tab;

NUM

--------------------------

NUM_TAB_TYP(1, 2, 3, 4, 5)

NUM_TAB_TYP(1, 3, 5)

NUM_TAB_TYP(2, 4, 6)

多重集运算符 EXCEPT 可以实现查询中查询出不包含于另一个嵌套表的所有的值。 例如在下面这个例子中,查询语句可以查出在嵌套表中除了1以外其他所有的值:

select num multiset except num_tab_typ(1) num from num_tab;

NUM

--------------------------

NUM_TAB_TYP(2, 3, 4, 5)

NUM_TAB_TYP(3, 5)

NUM_TAB_TYP(2, 4, 6)

多重集运算符INTERSECT 则是与 Except 相反,它可以返回在两个嵌套表中相同的值。那么,如果使用一个嵌套表,表中只有一个数字“1”,那么如果在原来的嵌套表中没有“1”则返回的结果为一个空集,但是如原来的嵌套表中确实存在“1”,那么返回的结果就是“1”,如下面的例子所示:

select num multiset intersect num_tab_typ(1) num from num_tab

NUM

--------------------------

NUM_TAB_TYP(1)

NUM_TAB_TYP(1)

NUM_TAB_TYP()

    黑客防线网安服务器维护方案本篇连接:http://www.rongsen.com.cn/show-12724-1.html
网站维护教程更新时间:2012-03-23 00:45:06  【打印此页】  【关闭
我要申请本站N点 | 黑客防线官网 |  
专业服务器维护及网站维护手工安全搭建环境,网站安全加固服务。黑客防线网安服务器维护基地招商进行中!QQ:29769479

footer  footer  footer  footer