Pular para o conteúdo principal

argMax

Introduzido em: v1.1.0 Calcula o valor de arg correspondente ao valor máximo de val. Se houver várias linhas com val iguais ao máximo, não é determinístico qual dos arg associados será retornado. As duas partes, arg e max, se comportam como funções de agregação; ambas ignoram Null durante o processamento e retornam valores diferentes de Null se houver valores diferentes de Null disponíveis. Veja também Sintaxe
argMax(arg, val)
Argumentos Valor retornado Retorna o valor de arg correspondente ao valor máximo de val. O tipo corresponde ao tipo de arg. Exemplos Uso básico
Query
SELECT argMax(user, salary) FROM salary;
Response
┌─argMax(user, salary)─┐
│ director             │
└──────────────────────┘
Exemplo mais completo com tratamento de 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 │
└──────────────┴────────┘
Usando Tuple nos argumentos
Query
SELECT argMax(a, (b,a)) FROM test;
Response
┌─argMax(a, tuple(b, a))─┐
│ c                      │
└────────────────────────┘
Última modificação em 10 de junho de 2026