Перейти к основному содержимому
Перейти к основному содержимому

argMax

argMax

Впервые представлена в версии v1.1

Вычисляет значение arg для максимального значения val. Если существует несколько строк с одинаковым максимальным val, то выбор возвращаемого связанного значения arg недетерминирован. И arg, и max ведут себя как агрегатные функции, при обработке они обе пропускают значения Null и возвращают значения, отличные от Null, если такие значения доступны.

См. также

Синтаксис

argMax(arg, val)

Аргументы

Возвращаемое значение

Возвращает значение arg, которое соответствует максимальному значению val. Тип совпадает с типом arg.

Примеры

Базовое использование

SELECT argMax(user, salary) FROM salary;
┌─argMax(user, salary)─┐
│ director             │
└──────────────────────┘

Подробный пример с обработкой значений 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), max(b) FROM test;
┌─argMax(a, b)─┬─max(b)─┐
│ b            │      3 │
└──────────────┴────────┘

Использование Tuple в аргументах

SELECT argMax(a, (b,a)) FROM test;
┌─argMax(a, tuple(b, a))─┐
│ c                      │
└────────────────────────┘