メインコンテンツまでスキップ
メインコンテンツまでスキップ

maxMap

説明

Map 組み合わせ関数は、max 関数に適用して、各キーに基づいて Map 内の最大値を計算するために maxMap 集約組み合わせ関数を使用できます。

使用例

この例では、ステータスコードとそれぞれの時間帯におけるカウントを格納するテーブルを作成します。各行には、ステータスコードとその対応するカウントの Map が含まれます。maxMap を使用して、各時間帯内の各ステータスコードの最大カウントを見つけます。

CREATE TABLE metrics(
    date Date,
    timeslot DateTime,
    status Map(String, UInt64)
) ENGINE = Log;

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,
    maxMap(status),
FROM metrics
GROUP BY timeslot;

maxMap 関数は、各時間帯内の各ステータスコードの最大カウントを見つけます。例えば:

  • 時間帯 '2000-01-01 00:00:00':
    • ステータス 'a': 15
    • ステータス 'b': 25
    • ステータス 'c': max(35, 45) = 45
    • ステータス 'd': 55
    • ステータス 'e': 65
  • 時間帯 '2000-01-01 00:01:00':
    • ステータス 'd': 75
    • ステータス 'e': 85
    • ステータス 'f': max(95, 105) = 105
    • ステータス 'g': max(115, 125) = 125
   ┌────────────timeslot─┬─maxMap(status)───────────────────────┐
1. │ 2000-01-01 00:01:00 │ {'d':75,'e':85,'f':105,'g':125}      │
2. │ 2000-01-01 00:00:00 │ {'a':15,'b':25,'c':45,'d':55,'e':65} │
   └─────────────────────┴──────────────────────────────────────┘

参照