메인 콘텐츠로 건너뛰기

argAndMax

도입 버전: v1.1.0 최대 val 값에 대한 argval 값을 계산합니다. 최대값과 같은 val을 가진 행이 여러 개인 경우, 해당하는 argval 중 어떤 값이 반환될지는 결정적이지 않습니다. argmax 두 부분은 모두 집계 함수처럼 동작하며, 처리 중에 Null을 건너뛰고 Null이 아닌 값을 사용할 수 있으면 Null이 아닌 값을 반환합니다.
argMax와의 유일한 차이점은 argAndMax가 인수와 값을 모두 반환한다는 점입니다.
관련 항목 구문
argAndMax(arg, val)
인수 반환 값 최대 val 값에 대응하는 arg 값과 최대 val 값을 포함하는 튜플을 반환합니다. Tuple 예시 기본 사용법
Query
SELECT argAndMax(user, salary) FROM salary;
Response
┌─argAndMax(user, salary)─┐
│ ('director',5000)       │
└─────────────────────────┘
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), argAndMax(a, b), max(b) FROM test;
Response
┌─argMax(a, b)─┬─argAndMax(a, b)─┬─max(b)─┐
│ b            │ ('b',2)         │      3 │
└──────────────┴─────────────────┴────────┘
인수에서 Tuple 사용하기
Query
SELECT argAndMax(a, (b,a)) FROM test;
Response
┌─argAndMax(a, (b, a))─┐
│ ('c',(2,'c'))        │
└──────────────────────┘
관련 항목
마지막 수정일 2026년 6월 10일