ARRAY_FIRST
説明
lambda bool式と配列を入力パラメータとして使用します。lambda式は他の入力ARRAYパラメータの内部データを評価するために使用されます。 lambda(arr1[i])が0以外の値を返す配列内の最初の要素を返します。
構文
ARRAY_FIRST(<lambda>, <arr>)
パラメータ
| Parameter | デスクリプション |
|---|---|
<lambda> | 入力パラメータが指定された配列の列数と一致する必要があるlambda式。この式は有効なスカラー関数を実行できますが、集約関数はサポートしていません。 |
<arr> | ARRAY配列 |
Return Value
最初の非ゼロ値のインデックスを返します。該当するインデックスが見つからない場合は、NULLを返します。
Example
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 |
+---------------------------------------------------------------------------------------------+