当前位置: 首页 > 面试题库 >

选择按5分钟周期分组的平均记录

羊越
2023-03-14
问题内容

我有一个小问题。我有这样格式的PostgreSQL表

time (datetime)     | players (int) | servers (int)
---------------------------------------------------
2013-12-06 13:40:01 | 80            | 20
2013-12-06 13:41:13 | 78            | 21
etc.

我想按5分钟的时间对它们进行分组,并将该组的平均值作为一个单一值,因此将有20%的记录,每条记录平均包含〜5个数字,而时间设置为中的第一个时间值群组。我不知道如何在PgSQL中执行此操作。因此结果将是:

2013-12-06 13:40:01 | avg of players on :40, :41, :42, :43, :44 | same with servers
2013-12-06 13:45:05 | avg of players on :45, :46, :47, :48, :49 | same with servers
2013-12-06 13:50:09 | avg of players on :50, :51, :52, :53, :54 | same with servers
2013-12-06 13:55:12 | avg of players on :55, :56, :57, :58, :59 | same with servers

问题答案:
SELECT grid.t5
      ,min(t."time") AS min_time
--    ,array_agg(extract(min FROM t."time")) AS 'players_on' -- optional
      ,avg(t.players) AS avg_players
      ,avg(t.servers) AS avg_servers
FROM (
   SELECT generate_series(min("time")
                         ,max("time"), interval '5 min') AS t5
   FROM tbl
   ) grid
LEFT JOIN tbl t ON t."time" >= grid.t5
               AND t."time" <  grid.t5 +  interval '5 min'
GROUP  BY grid.t5
ORDER  BY grid.t5;

解释

  • 子查询grid每5分钟从表中的最小值“到最大值”产生一行记录time"

  • 以5分钟为间隔将LEFT JOIN返回表切片数据。仔细 包括 下边框,并 排除 上边框。

  • 要在没有任何反应的情况下放5分钟的时隙,请使用JOIN代替LEFT JOIN

  • 要使网格时间从0:00、5:00等开始,请向下舍min("time")generate_series()

这些相关答案中的更多解释:
数据间隔分组
PostgreSQL:“按分钟”运行查询的行数

另外:我不会使用它time作为标识符。它是标准SQL中的保留字,而在Postgres中是函数/类型名。



 类似资料:
  • 问题内容: 我有Laravel应用程序,我每3秒钟定期检查一次用户的心跳登录状态(演示目的,实际上是5分钟)。对于每个节拍,我都会检查用户在当前时间的上一次活动是否也为5分钟。如果是这样,请注销它们。 这是我的代码: 我的问题是,这行不通。如果我将操作数更改为,它将在5分钟前立即注销我,如果操作数为,即使5分钟后它也不会注销我,有人可以解释为什么吗? -编辑- 感谢您提供所有答案,我通过将代码修改

  • 问题内容: 我有一个这样的数据框: 我想计算每个集群每个组织的平均时间。 预期结果: 我不知道如何在熊猫中做到这一点,有人可以帮忙吗? 问题答案: 如果你想先对组合取平均值,然后再对cluster组取平均值 如果你不仅仅希望价值观,那么你可以 你可以groupby上再取

  • 问题内容: 从下面的数据中,我需要使用SQL Server 2005为每个链接ID选择最接近指定日期的记录: 因此,使用01/10/2010选择它们应返回: 我知道这是有可能的,但似乎无法绕开我的头脑(必须太接近一天的结束了:P)如果有人可以帮助或朝正确的方向轻轻推一下,将不胜感激! 编辑: 另外我也遇到了这个sql以获取最接近的日期: 但无法弄清楚如何正确地整合到查询中… 谢谢 问题答案: 你可

  • 问题内容: 我试图通过取元素的平均值将numpy数组分组为较小的大小。例如,将100x100阵列中的平均5x5子阵列的foreach平均值创建20x20大小的阵列。由于需要处理大量数据,这是一种有效的方法吗? 问题答案: 我已经尝试过使用较小的阵列,因此请与您的阵列进行测试: 6x6-> 3x3的示例:

  • 问题内容: 我有一个这样的表: 我需要一个查询以n分钟的间隔对记录进行分组。 例如,输出(按60分钟分组): 到目前为止,由于间隔介于0到60分钟之间,因此我一直在使用此查询按10分钟间隔进行分组: 但是现在间隔可以是例如 125436758 分钟。 我无法创建新表,并且用户定义的间隔必须为n分钟。我正在使用SQL SERVER2012。谢谢。 问题答案:

  • 问题内容: 我有桌子: 当我直接通过MySQL查询时,它可以按我的要求完美运行 但是,当我尝试将此查询转换为ActiveRecord语法时,它返回nil。 如您所见,两个示例中的最终查询均相等。为什么在ActiveRecord情况下不起作用? 在我的rails项目中使用Rails 4.0.0,Ruby 2.0和mysql db。 问题答案: 我认为您对控制台输出感到有些困惑。 你是这样说的: 因此