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