首页 > 解决方案 > 如何在 Presto SQL 中按 X 分钟增量分组?

问题描述

我的数据集如下所示:

Name, Timestamp, Period, Value
Apple, 2012-03-22 00:00:00.000, 10, 34
Apple, 2012-03-22 00:06:00.000, 10, 23
Orange, 2012-03-22 00:00:00.000, 5, 3
Orange, 2012-03-22 00:08:00.000, 5, 45

如果列周期是 N 分钟数,则应按每小时分组。因此,例如,Apple 应该在 1:10、1:20、1:30 ex 分组,其中 Orange 是 1:05、1:10 等。我还想在每个增量上平均 Value 列。

标签: sqlpresto

解决方案


假设

  • Period是整数和 60 的除数
  • 对于两行,如果Name相同,Period则相同

以下应该做

SELECT
    name,
    date_trunc('minute', timestamp_column)
      - interval '1' minute * (minute(timestamp_column) % period)
      AS timestamp_rounded,
    avg(value)
FROM ...
GROUP BY 1, 2

推荐阅读