메인 콘텐츠로 건너뛰기

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일