본문으로 바로가기
본문으로 바로가기

argAndMax

argAndMax

도입 버전: v1.1

최대 val 값에 해당하는 argval 값을 계산합니다. 최대가 되는 동일한 val 값을 가진 행이 여러 개 있는 경우, 어떤 argval 조합이 반환될지는 비결정적입니다. argmax 두 부분 모두 집계 함수처럼 동작하며, 처리 중에 둘 다 Null을 건너뛰고, Null이 아닌 값이 존재하는 경우 Null이 아닌 값을 반환합니다.

참고

argMax와의 유일한 차이점은 argAndMax가 인자와 값을 모두 반환한다는 점입니다.

함께 보기

구문

argAndMax(arg, val)

인수

반환 값

최대 val 값에 대응하는 arg 값과 그 최대 val 값을 포함하는 튜플(Tuple)을 반환합니다. Tuple

예시

기본 사용법

SELECT argAndMax(user, salary) FROM salary;
┌─argAndMax(user, salary)─┐
│ ('director',5000)       │
└─────────────────────────┘

NULL 처리를 포함한 확장 예제

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;
┌─argMax(a, b)─┬─argAndMax(a, b)─┬─max(b)─┐
│ b            │ ('b',2)         │      3 │
└──────────────┴─────────────────┴────────┘

인수로 Tuple 사용하기

SELECT argAndMax(a, (b,a)) FROM test;
┌─argAndMax(a, (b, a))─┐
│ ('c',(2,'c'))        │
└──────────────────────┘

함께 보기