YashanDB ARRAY_POSITION函数

本文内容来自YashanDB官网,原文内容请见 https://doc.yashandb.com/yashandb/23.3/zh/开发手册/SQL参考手册/内置函数/ARRAY_POSITION.html

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 
------------ 
           

posted @ 2025-04-09 18:57  YashanDB  阅读(5)  评论(0)    收藏  举报