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

timeSeriesGroupArray

Сортирует временные ряды по метке времени по возрастанию.

Синтаксис

timeSeriesGroupArray(timestamp, value)

Аргументы

  • timestamp — временная метка выборки
  • value — значение временного ряда, соответствующее timestamp

Возвращаемое значение

Функция возвращает массив кортежей (timestamp, value), отсортированный по возрастанию timestamp. Если для одного и того же timestamp существует несколько значений, функция выбирает наибольшее из них.

Пример

WITH
    [110, 120, 130, 140, 140, 100]::Array(UInt32) AS timestamps,
    [1, 6, 8, 17, 19, 5]::Array(Float32) AS values -- массив значений, соответствующих временным меткам выше
SELECT timeSeriesGroupArray(timestamp, value)
FROM
(
    -- Данный подзапрос преобразует массивы временных меток и значений в строки с полями `timestamp` и `value`
    SELECT
        arrayJoin(arrayZip(timestamps, values)) AS ts_and_val,
        ts_and_val.1 AS timestamp,
        ts_and_val.2 AS value
);

Ответ:

   ┌─timeSeriesGroupArray(timestamp, value)───────┐
1. │ [(100,5),(110,1),(120,6),(130,8),(140,19)]   │
   └──────────────────────────────────────────────┘

Также можно передавать несколько меток времени и значений в виде массивов одинаковой длины. Тот же запрос с аргументами-массивами:

WITH
    [110, 120, 130, 140, 140, 100]::Array(UInt32) AS timestamps,
    [1, 6, 8, 17, 19, 5]::Array(Float32) AS values -- массив значений, соответствующих указанным выше временным меткам
SELECT timeSeriesGroupArray(timestamps, values);
Примечание

Эта функция экспериментальная; включите её, установив allow_experimental_ts_to_grid_aggregate_function=true.