メインコンテンツまでスキップ
バージョン: 4.x

ARRAY_LAST

説明

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

構文

ARRAY_LAST(<lambda>, <arr>)

パラメータ

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

戻り値

最後の非ゼロ値のインデックスを返します。該当するインデックスが見つからない場合は、NULLを返します。

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