跳转到主要内容

argMin

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