Перейти к основному содержанию

Описание

Комбинатор Map можно применять к функции min, чтобы с помощью агрегатной функции-комбинатора minMap вычислять минимальное значение в Map для каждого ключа.

Пример использования

В этом примере мы создадим таблицу, в которой хранятся коды состояния и их количество для разных временных интервалов, где каждая строка содержит Map кодов состояния и соответствующих им значений количества. Мы будем использовать 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} │
   └─────────────────────┴──────────────────────────────────────┘

См. также

Последнее изменение 10 июня 2026 г.