image.png
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。

示例(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 
------------

YashanDB
1 声望0 粉丝

崖山数据库系统YashanDB是深圳计算科学研究院自主设计研发的新型数据库管理系统,融入原创的有界计算、近似计算、并行可扩展和跨模融合计算理论,可满足金融、政企、能源等关键行业对高性能、高并发及高安全性的...