我有一个表(MySQL),每 n 秒捕获一次样本。该表有许多列,但所有重要的列只有两个:时间戳(TIMESTAMP 类型)和计数(INT 类型)。

我想要做的是在一段时间内获得计数列的总和和平均值。例如,我每 2 秒记录一次样本,但我想要所有样本的 10 秒或 30 秒窗口中所有样本的计数列的总和。

下面是一个数据示例:

+---------------------+-----+
|时间戳 |计数 |
+---------------------+-----+
| 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 | # 这是 00 - 30 秒范围的总和
| 2010-06-15 23:35:30 | 7544 | # 这是 30 - 60 秒范围的总和
| 2010-06-17 10:39:35 | 450 | # 这是 30 - 60 秒范围的总和
+---------------------+-----+

我已经使用 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/

10-17 03:08