메인 콘텐츠로 건너뛰기

설명

조합자는 min 함수에 적용할 수 있으며, minMap 집계 조합자 함수를 사용해 각 키별로 맵의 최솟값을 계산합니다.

예시 사용

이 예시에서는 서로 다른 시간 슬롯별 상태 코드와 해당 개수를 저장하는 테이블을 생성합니다. 각 행에는 상태 코드와 그에 대응하는 개수가 담긴 맵이 포함됩니다. 각 시간 슬롯 내에서 각 상태 코드의 최소 개수를 찾기 위해 minMap을 사용합니다.
Query
CREATE TABLE metrics(
    date Date,
    timeslot DateTime,
    status Map(String, UInt64)
) ENGINE = MergeTree
ORDER BY ();

INSERT INTO metrics VALUES
    ('2000-01-01', '2000-01-01 00:00:00', (['a', 'b', 'c'], [15, 25, 35])),
    ('2000-01-01', '2000-01-01 00:00:00', (['c', 'd', 'e'], [45, 55, 65])),
    ('2000-01-01', '2000-01-01 00:01:00', (['d', 'e', 'f'], [75, 85, 95])),
    ('2000-01-01', '2000-01-01 00:01:00', (['f', 'g', 'g'], [105, 115, 125]));

SELECT
    timeslot,
    minMap(status),
FROM metrics
GROUP BY timeslot;
minMap 함수는 각 타임슬롯에서 상태 코드별 최소 개수를 찾습니다. 예시는 다음과 같습니다:
  • 타임슬롯 ‘2000-01-01 00:00:00’의 경우:
    • 상태 ‘a’: 15
    • 상태 ‘b’: 25
    • 상태 ‘c’: min(35, 45) = 35
    • 상태 ‘d’: 55
    • 상태 ‘e’: 65
  • 타임슬롯 ‘2000-01-01 00:01:00’의 경우:
    • 상태 ‘d’: 75
    • 상태 ‘e’: 85
    • 상태 ‘f’: min(95, 105) = 95
    • 상태 ‘g’: min(115, 125) = 115
Response
   ┌────────────timeslot─┬─minMap(status)───────────────────────┐
1. │ 2000-01-01 00:01:00 │ {'d':75,'e':85,'f':95,'g':115}       │
2. │ 2000-01-01 00:00:00 │ {'a':15,'b':25,'c':35,'d':55,'e':65} │
   └─────────────────────┴──────────────────────────────────────┘

관련 항목

마지막 수정일 2026년 6월 10일