mysql - SELECT/GROUP BY - 时间段(10 秒、30 秒等)

标签 mysql sql select group-by

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

相关文章:

php - 如何在 PHP 中使用 PDO 从 SQL Server 数据库中获取数据并在 UTF-8 编码的 MySQL 数据库中正确编码?

MySQL 相当于 MS SQL 交叉应用

php - 如何用PDO代替MySQL函数?

php - mysql_fetch_array 不会呈现 SQL 查询的期望值

Mysql 数据库连接详细信息在包含的文件中永远不起作用

php - 将 mysql_num_rows 更新为新的 Mysqli 标准 : mysqli_stmt_num_rows

MySQL 需要有关查询的建议

Java DB和jasper报告嵌套选择

MySQL 表枢轴 - 动态

mysql - 如何仅使用SQL选择表A中的列,按分隔符拆分其并将分隔值插入到其他表中?