跳转到主要内容

argMax

引入版本:v1.1.0 计算最大 val 值对应的 arg 值。如果有多行的 val 同为最大值,则返回哪个关联的 arg 是不确定的。 argmax 这两部分都作为聚合函数处理:它们在处理过程中都会跳过 Null,如果存在非 Null 值,则返回非 Null 值。 另请参见 语法
argMax(arg, val)
参数 返回值 返回与最大 val 值对应的 arg 值。返回类型与 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                      │
└────────────────────────┘
最后修改于 2026年6月10日