#ARRAY_POSITION
ARRAY_POSITION函数以start_locate为起点查找数组(数组变量,数组对象,数组类型)array_var的成员中第一个出现compare_member的位置,并返回INT类型的该位置值。
array_var
数组变量,其值可以为:
- 一个存在的数组,数组成员必须为普通标量数据类型。
- NULL,此时函数返回NULL。
compare_member
通用表达式,其值类型必须为与array_var数组成员可进行比较的类型,具体参考YashanDB的比较运算规则。
start_locate
通用表达式,不可为NULL,其值类型须为INT,或可隐式转换为INT。
当start_locate为负数,或者超过数组长度时,函数返回NULL。
示例
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
------------