メインコンテンツまでスキップ

ARRAY_FIRST

説明

ラムダのbool式と配列を入力パラメータとして使用し、ラムダ式は他の入力ARRAY パラメータの内部データを評価するために使用されます。 lambda(arr1[i]) が 0 以外の値を返す配列内の最初の要素を返します。

構文

ARRAY_FIRST(<lambda>, <arr>)

パラメータ

パラメータ説明
<lambda>入力パラメータが指定された配列の列数と一致する必要があるラムダ式。この式では有効なスカラー関数を実行できますが、集約関数はサポートされません。
<arr>ARRAY配列

戻り値

最初の非ゼロ値のインデックスを返します。そのようなインデックスが見つからない場合は、NULLを返します。

select array_first(x->x>2, [1,2,3,0]);
+------------------------------------------------------------------------------------------------+
| array_first(array_filter(ARRAY(1, 2, 3, 0), array_map([x] -> x(0) > 2, ARRAY(1, 2, 3, 0))), -1)|
+------------------------------------------------------------------------------------------------+
| 3 |
+------------------------------------------------------------------------------------------------+
select array_first(x->x>4, [1,2,3,0]); 
+------------------------------------------------------------------------------------------------+
| array_first(array_filter(ARRAY(1, 2, 3, 0), array_map([x] -> x(0) > 4, ARRAY(1, 2, 3, 0))), -1)|
+------------------------------------------------------------------------------------------------+
| NULL |
+------------------------------------------------------------------------------------------------+
select array_first(x->x>1, [1,2,3,0]);
+---------------------------------------------------------------------------------------------+
| array_first(array_filter(ARRAY(1, 2, 3, 0), array_map([x] -> x > 1, ARRAY(1, 2, 3, 0))), 1) |
+---------------------------------------------------------------------------------------------+
| 2 |
+---------------------------------------------------------------------------------------------+