メインコンテンツへスキップ
メインコンテンツへスキップ

argAndMax

argAndMax

導入バージョン: v1.1

最大のval値に対するargvalの値を計算します。 最大値となる同じvalを持つ行が複数存在する場合、どのargvalが返されるかは非決定的です。 argmaxの両方の部分は集約関数として動作し、処理中にNullをスキップし、Nullでない値が利用可能な場合はNullでない値を返します。

注記

argMaxとの唯一の違いは、argAndMaxが引数と値の両方を返す点です。

関連項目

構文

argAndMax(arg, val)

引数

返り値

最大の val に対応する arg の値と、その最大の val を要素とするタプルを返します。Tuple

基本的な使い方

SELECT argAndMax(user, salary) FROM salary;
┌─argAndMax(user, salary)─┐
│ ('director',5000)       │
└─────────────────────────┘

NULL 処理を含む拡張例

CREATE TABLE test
(
    a Nullable(String),
    b Nullable(Int64)
)
ENGINE = Memory AS
SELECT *
FROM VALUES(('a', 1), ('b', 2), ('c', 2), (NULL, 3), (NULL, NULL), ('d', NULL));

SELECT argMax(a, b), argAndMax(a, b), max(b) FROM test;
┌─argMax(a, b)─┬─argAndMax(a, b)─┬─max(b)─┐
│ b            │ ('b',2)         │      3 │
└──────────────┴─────────────────┴────────┘

引数での Tuple の利用

SELECT argAndMax(a, (b,a)) FROM test;
┌─argAndMax(a, (b, a))─┐
│ ('c',(2,'c'))        │
└──────────────────────┘

関連項目