我有一个表 (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/