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

argMin

Добавленный в: v1.1.0 Вычисляет значение arg, соответствующее минимальному значению val. Если есть несколько строк с одинаковым val, то какой именно из связанных arg будет возвращён, недетерминированно. Обе части — arg и min — ведут себя как агрегатные функции: обе пропускают Null при обработке и возвращают значения, отличные от Null, если доступны значения, отличные от Null. См. также Синтаксис
argMin(arg, val)
Аргументы Возвращаемое значение Возвращает значение arg, соответствующее минимальному значению val. Тип совпадает с типом arg. Примеры Базовое использование
Query
SELECT argMin(user, salary) FROM salary;
Response
┌─argMin(user, salary)─┐
│ worker               │
└──────────────────────┘
Расширенный пример обработки NULL
Query
CREATE TABLE test
(
    a Nullable(String),
    b Nullable(Int64)
)
ENGINE = Memory AS
SELECT *
FROM VALUES((NULL, 0), ('a', 1), ('b', 2), ('c', 2), (NULL, NULL), ('d', NULL));

SELECT argMin(a, b), min(b) FROM test;
Response
┌─argMin(a, b)─┬─min(b)─┐
│ a            │      0 │
└──────────────┴────────┘
Использование типа Tuple в аргументах
Query
SELECT argMin(a, (b, a)), min(tuple(b, a)) FROM test;
Response
┌─argMin(a, tuple(b, a))─┬─min(tuple(b, a))─┐
│ d                      │ (NULL,NULL)      │
└────────────────────────┴──────────────────┘
Последнее изменение 10 июня 2026 г.