- mongodb - 在 MongoDB mapreduce 中,如何展平值对象?
- javascript - 对象传播与 Object.assign
- html - 输入类型 ="submit"Vs 按钮标签它们可以互换吗?
- sql - 使用 MongoDB 而不是 MS SQL Server 的优缺点
我有一个表 (MySQL),它每 n 秒捕获一次样本。该表有很多列,但最重要的是两列:一个时间戳(TIMESTAMP 类型)和一个计数(INT 类型)。
我想做的是获取计数列在一段时间内的总和和平均值。例如,我每 2 秒记录一次样本,但我想要所有样本在 10 秒或 30 秒窗口中的所有样本的计数列的总和。
以下是数据示例:
+---------------------+-----------------+| time_stamp | count |+---------------------+-----------------+| 2010-06-15 23:35:28 | 1 || 2010-06-15 23:35:30 | 1 || 2010-06-15 23:35:30 | 1 || 2010-06-15 23:35:30 | 942 || 2010-06-15 23:35:30 | 180 || 2010-06-15 23:35:30 | 4 || 2010-06-15 23:35:30 | 52 || 2010-06-15 23:35:30 | 12 || 2010-06-15 23:35:30 | 1 || 2010-06-15 23:35:30 | 1 || 2010-06-15 23:35:33 | 1468 || 2010-06-15 23:35:33 | 247 || 2010-06-15 23:35:33 | 1 || 2010-06-15 23:35:33 | 81 || 2010-06-15 23:35:33 | 16 || 2010-06-15 23:35:35 | 1828 || 2010-06-15 23:35:35 | 214 || 2010-06-15 23:35:35 | 75 || 2010-06-15 23:35:35 | 8 || 2010-06-15 23:35:37 | 1799 || 2010-06-15 23:35:37 | 24 || 2010-06-15 23:35:37 | 11 || 2010-06-15 23:35:37 | 2 || 2010-06-15 23:35:40 | 575 || 2010-06-15 23:35:40 | 1 || 2010-06-17 10:39:35 | 2 || 2010-06-17 10:39:35 | 2 || 2010-06-17 10:39:35 | 1 || 2010-06-17 10:39:35 | 2 || 2010-06-17 10:39:35 | 1 || 2010-06-17 10:39:40 | 35 || 2010-06-17 10:39:40 | 19 || 2010-06-17 10:39:40 | 37 || 2010-06-17 10:39:42 | 64 || 2010-06-17 10:39:42 | 3 || 2010-06-17 10:39:42 | 31 || 2010-06-17 10:39:42 | 7 || 2010-06-17 10:39:42 | 246 |+---------------------+-----------------+
我想要的输出(基于上面的数据)应该是这样的:
+---------------------+-----------------+| 2010-06-15 23:35:00 | 1 | # This is the sum for the 00 - 30 seconds range| 2010-06-15 23:35:30 | 7544 | # This is the sum for the 30 - 60 seconds range| 2010-06-17 10:39:35 | 450 | # This is the sum for the 30 - 60 seconds range+---------------------+-----------------+
我使用 GROUP BY 按秒或按分钟收集这些数字,但我似乎无法弄清楚使亚分钟或秒范围 GROUP BY 命令正常工作的语法。
我将主要使用此查询将数据从该表中抽取到另一个表中。
谢谢!
最佳答案
GROUP BY UNIX_TIMESTAMP(time_stamp) DIV 30
或者说出于某种原因您想以 20 秒的间隔对它们进行分组,这将是 DIV 20
等。要更改 GROUP BY
值之间的边界,您可以使用
GROUP BY (UNIX_TIMESTAMP(time_stamp) + r) DIV 30
其中 r
是小于 30 的文字非负整数。所以
GROUP BY (UNIX_TIMESTAMP(time_stamp) + 5) DIV 30
应该给你 hh:mm:05 和 hh:mm:35 之间以及 hh:mm:35 和 hh:mm+1:05 之间的总和。
关于mysql - SELECT/GROUP BY - 时间段(10 秒、30 秒等),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3086386/
如果我使用以下方法计算 java.time 中 2 个 LocalDate 之间的差异: Period p = Period.between(testDate, today); 然后我得到一个包含年、
我正在开发一个有多种不同费率的预订平台。这些费率由一天中的时间、星期几和一年中的一天决定。以下是所涉及的间隔类型的一些示例: 周一至周五,上午 9 点至下午 5 点 周六和周日,中午 12 点到早上
我有大量数据,包括开始时间、停止时间和值。开始和停止时间因行而异,以 5 分钟为增量。我正在尝试创建一个新的数据框,该数据框具有 5 分钟的间隔以及该间隔在行的开始和停止范围内的所有行的总和。 我有一
我有一个这样的表: --------------------------------------------- |Id | Step | StartedAt
我有一个网络应用程序,用户将在其中输入 2 个日期。一个 StartDate 和一个 EndDate。现在我想编写它,以便在选择 StartDate 和 EndDate 时确定有多少周,然后显示这些周
这看起来并不直截了当。 我正在尝试: @Override public int compare(Period o1, Period o2) { return o1.toStandardDays
我必须为团队发送 session 邀请,这是我的邮件 $ical = 'BEGIN:VCALENDAR PRODID:-//Microsoft Corporation//Outlook 11.0
我有这个 ISO 8601 时间段字符串: P0Y0M0DT3H5M0.000S 并且 PHP7.4 无法用它构造 DateInterval。 format('%h Hours %m Minutes
我想要获取包含一段时间(格式为 HH:MM:SS)的多个单元格的总和。在 LibreOffice Calc 4.0.3.3 中,我复制粘贴了 G14:G21 范围内的时间段,并将单元格格式设置为时间
我有一个表(MySQL),每n秒捕获一次样本。该表有很多列,但重要的是两列:时间戳(TIMESTAMP 类型)和计数(INT 类型)。 我想做的是获取一定时间范围内计数列的总和和平均值。例如,我每 2
我有一个表(MySQL),每n秒捕获一次样本。该表有很多列,但重要的是两列:时间戳(TIMESTAMP 类型)和计数(INT 类型)。 我想做的是获取一定时间范围内计数列的总和和平均值。例如,我每 2
我在一个项目上使用 joda-time (1.6.2),我正在做的其中一件事就是计算预测时间和实际时间之间的差异。这种差异有时是积极的,有时是消极的。虽然适当的方法可能是使用 Duration 而不是
我有一个表 (MySQL),它每 n 秒捕获一次样本。该表有很多列,但最重要的是两列:一个时间戳(TIMESTAMP 类型)和一个计数(INT 类型)。 我想做的是获取计数列在一段时间内的总和和平均值
我想让我的折线图显示过去 3 个月的数据。 GDS 有一个“最后一个季度”的日期范围,但这显示的是 Q1、Q2、Q3 或 Q4。我需要的是过去3个整月(不算当月)的数据。我尝试创建一个计算字段,但事实
我想让我的折线图显示过去 3 个月的数据。 GDS 有一个“最后一个季度”的日期范围,但这显示的是 Q1、Q2、Q3 或 Q4。我需要的是过去3个整月(不算当月)的数据。我尝试创建一个计算字段,但事实
我是一名优秀的程序员,十分优秀!