mysql - 如何使用 Google BigQuery 按时间间隔分组
问题描述
我每 5 分钟记录一次 TIMESTAMP 天气数据,我想以 15 分钟的间隔进行分组。我发现下面的 floor 函数看起来很有希望,但是 BQ 不支持 UNIX_TIMESTAMP 函数
SELECT
FLOOR(UNIX_TIMESTAMP(utc_timestamp)/(15 * 60)) AS timekey
GROUP BY
timekey
做这个的最好方式是什么?
解决方案
以下是 BigQuery 标准 SQL
#standardSQL
SELECT
TIMESTAMP_SECONDS(15*60 * DIV(UNIX_SECONDS(utc_timestamp), 15*60)) timekey,
AVG(metric) metric
FROM `project.dataset.table`
GROUP BY timekey
您可以使用虚拟数据进行测试,使用上面的示例,如下例所示
#standardSQL
WITH `project.dataset.table` AS (
SELECT TIMESTAMP '2019-03-15 00:00:00' utc_timestamp, 1 metric UNION ALL
SELECT '2019-03-15 00:05:00', 2 UNION ALL
SELECT '2019-03-15 00:10:00', 3 UNION ALL
SELECT '2019-03-15 00:15:00', 4 UNION ALL
SELECT '2019-03-15 00:20:00', 5 UNION ALL
SELECT '2019-03-15 00:25:00', 6 UNION ALL
SELECT '2019-03-15 00:30:00', 7 UNION ALL
SELECT '2019-03-15 00:35:00', 8 UNION ALL
SELECT '2019-03-15 00:40:00', 9
)
SELECT
TIMESTAMP_SECONDS(15*60 * DIV(UNIX_SECONDS(utc_timestamp), 15*60)) timekey,
AVG(metric) metric
FROM `project.dataset.table`
GROUP BY timekey
-- ORDER BY timekey
结果
Row timekey metric
1 2019-03-15 00:00:00 UTC 2.0
2 2019-03-15 00:15:00 UTC 5.0
3 2019-03-15 00:30:00 UTC 8.0
显然,您可以使用逻辑所需的任何聚合 - 我使用 AVG() 只是为了举例
推荐阅读
- java - 在 tomat 上部署的根映射(“/”)上的 Spring Boot 404。(轻松依赖问题)
- python - 如何修剪 keras ResNet50 预训练权重(.h5 文件)?我只有 .h5 权重文件。(我已经成功加载了 keras 权重)
- c# - 如何在 C# 中评估包含局部变量名称的字符串作为代码
- sql-server - SQL:消息“无效的对象名称”是什么意思?
- java - 底部导航图标高度 Android
- angular - 如何安装较低版本的 Angular Material UI
- java - Spring Data Elastic Search vs Java High Level REST Client
- spring-boot - 在 Spring Data 中添加新的 DB 支持
- python - 有没有办法从其他 IDE 中的 python 脚本打开 notepad++ 中的文本文件?
- javascript - 为什么 useEffect 挂钩不能按预期工作?