EXISTS(N) |
如果第n个元素存在,返回TRUE |
COUNT |
该函数集合元素的数目 |
DELETE DELETE(n) DELETE(n,m) |
删除集合元素 l 删除所有元素 l 删除第n个元素 l 删除n到m的元素 |
FIRST |
返回集合第一个(最小的)元素索引号,如果集合为空,返回NULL |
LAST |
返回集合中最后一个(最大的)元素索引号,如果集合为空,返回NULL |
NEXT(n) |
返回集合当前元素的下n元素的索引号,如果它不存在就返回NULL |
PRIOR(n) |
返回集合当前元素的前n元素的索引号,如果它不存在就返回NULL |
LIMIT |
返回varray中创建元素的最大个数 |
EXTEND EXTEND(n) EXTEND(n,m) |
增加集合的大小。 l 添加一个,设为空 l 添加n个,设为空 l 添加n个,设为m |
TRIM TRIM(n) |
从集合末尾处删除元素 l 删除一个 l 删除n个 |
调用方法是: tab_col_name.COUNT
嵌套表运算符操作
例如:
var_tab_1 table_type;
var_tab_2 table_type;
var_tab_3 table_type;
reslut BOOLEAN;
var_tab_1 :=table_type('1','2');
var_tab_2 :=table_type('3','4');
var_tab_3 :=table_type('2','1');
result:= var_tab_1 =var_tab_3 result 为true;
result:= var_tab_2 >var_tab_3 result 为true;
IN 和 NOT IN 运算符
用于检测一个嵌套表的内容是否出现在令一个嵌套表的内容中。
result:= var_tab_1 IN (var_tab_3); result 为 TRUE;
result:= var_tab_2 NOT IN (var_tab_3); result 为 TRUE;
SUBMULITSET 子集运算符
检查一个嵌套表的内容是否为另外一个嵌套表的子集
result:= var_tab_1 SUBMULITSET OF var_tab_3 result 为TRUE;
MULTISET 集合运算符
返回的是一个嵌套集
MULTISET UNION
MULTISET INTERSECT
MULTISET EXCEPT
并 交 差 ,另外还有
ALL 全部
DISTINCT 去重
var_tab1 := var_tab2 MUSTISET UNION ALL var_tab2
CARDINALITY 获得嵌套表中元素数目
CARDINALITY(var_tab1)
(跟count 有什么不同。。- -!)
MEMBER OF 运算符
检测嵌套表的一个元素是否存在
'xxx' MEMBER OF var_tab1; 返回BOOLEAN
SET 运算符
将传入的嵌套表去重后返回
var_tab1 := SET (var_tab2);
IS A SET
判断时候符合每个元素都不同
result:= var_tab1 IS A SET;
IS EMPTY
判断嵌套表是否为空
COLLECT 运算符
将值列表作为嵌套表返回,可以配合 CAST 运算符将返回的嵌套表强制转换为一种嵌套表类型。
SELECT COLLECT(column_name) FROM TABLE WHERE expr;
POWERMULTISET
获得嵌套表的子嵌套表
SELECT * FROM TABLE( POWERMULTISET(table_tpye('1','2')) );
获得
注意:PS/SQL 不支持这个
POWERMULTISET_BY_CARDINALITY
获得指定长度以下的嵌套表
SELECT * FROM TABLE( POWERMULTISET_BY_CARDINALITY(table_tpye('1','2'),2) );
获得
PS/SQL 不支持这个