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

argAndMin

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