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

argMax

Добавленный в: v1.1.0 Вычисляет значение arg для максимального значения val. Если есть несколько строк с одинаковым максимальным значением val, то какой из соответствующих arg будет возвращён, не определено. Обе части — arg и max — ведут себя как агрегатные функции: обе пропускают Null во время обработки и возвращают значения, отличные от Null, если такие значения доступны. См. также Синтаксис
argMax(arg, val)
Аргументы Возвращаемое значение Возвращает значение arg, соответствующее максимальному значению val. Тип совпадает с типом arg. Примеры Базовое использование
Query
SELECT argMax(user, salary) FROM salary;
Response
┌─argMax(user, salary)─┐
│ director             │
└──────────────────────┘
Расширенный пример с обработкой значений NULL
Query
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;
Response
┌─argMax(a, b)─┬─max(b)─┐
│ b            │      3 │
└──────────────┴────────┘
Использование Tuple в качестве аргументов
Query
SELECT argMax(a, (b,a)) FROM test;
Response
┌─argMax(a, tuple(b, a))─┐
│ c                      │
└────────────────────────┘
Последнее изменение 10 июня 2026 г.