#ARRAY_POSITION

array_position
ARRAY_POSITION ( array_var , compare_member , start_locate )

ARRAY_POSITION函数以start_locate为起点查找数组(数组变量数组对象数组类型)array_var的成员中第一个出现compare_member的位置,并返回INT类型的该位置值。

该函数不支持向量化计算。

array_var

数组变量,其值可以为:

compare_member

通用表达式,其值类型必须为与array_var数组成员可进行比较的类型,具体参考YashanDB的比较运算规则

start_locate

通用表达式,不可为NULL,其值类型须为INT,或可隐式转换为INT。

当start_locate为负数,或者超过数组长度时,函数返回NULL。

示例(HEAP表)

CREATE OR REPLACE TYPE arr_position_type IS VARRAY(10) OF CHAR(5);
/

SELECT ARRAY_POSITION(arr_position_type('a', 'b', 'c', 'd'), 'c') pos FROM DUAL;
         POS 
------------ 
           3

SELECT ARRAY_POSITION(arr_position_type('a', 'b', NULL, 'd', 'c'), NULL) pos FROM DUAL;
         POS 
------------ 
           3

SELECT ARRAY_POSITION(arr_position_type('a', 'b', 'c', 'd', 'c'), 'c', 4) pos FROM DUAL;
         POS 
------------ 
           5

SELECT ARRAY_POSITION(arr_position_type('a', 'b', 'c', 'd', 'c'), 1, 4) pos FROM DUAL;
         POS 
------------ 
           
pdf-btn 下载文档
copy-btn 复制链接