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

argAndMin

argAndMin

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

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

Примечание

Единственное отличие от argMin заключается в том, что argAndMin возвращает и аргумент, и значение.

См. также

Синтаксис

argAndMin(arg, val)

Аргументы

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

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

Примеры

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

SELECT argAndMin(user, salary) FROM salary;
┌─argAndMin(user, salary)─┐
│ ('worker',1000)         │
└─────────────────────────┘

Расширенный пример с обработкой значений NULL

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;
┌─argMin(a, b)─┬─argAndMin(a, b)─┬─min(b)─┐
│ a            │ ('a',1)         │      0 │
└──────────────┴─────────────────┴────────┘

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

SELECT argAndMin(a, (b, a)), min(tuple(b, a)) FROM test;
┌─argAndMin(a, (b, a))─┬─min((b, a))─┐
│ ('a',(1,'a'))        │ (0,NULL)    │
└──────────────────────┴─────────────┘

См. также