spe*_*ool 3 mysql sql sql-date-functions
我在数据库中有一列,为一系列传感器读数提供日期时间戳.我想把那些读数分成不间断的连续传感器读数.如果传感器读数被破坏,则日期时间列中将存在不连续性.所以我想对datetime列执行查询,然后计算连续读数之间的差异.
假设我的查询是:
select sensor_time from sensor_table limit 10;
我得到:
+---------------------+
| sensor_time |
+---------------------+
| 2009-09-28 07:08:12 |
| 2009-09-28 07:08:40 |
| 2009-09-28 07:09:10 |
| 2009-09-28 07:09:40 |
| 2009-09-28 07:10:10 |
| 2009-09-28 07:10:40 |
| 2009-09-28 07:41:10 |
| 2009-09-28 07:41:40 |
| 2009-09-28 07:42:10 |
| 2009-09-28 07:42:40 |
+---------------------+
Run Code Online (Sandbox Code Playgroud)
这个例子中的时间突然从07:10跳到07:41,我想检测一下.我的问题是如何计算这10张日期时间邮票的9个时差?有没有办法将timediff()应用于整个查询?
在MySQL中,这非常简单,因为您可以使用变量来存储每行的传感器时间,然后在计算时间差时在下一行使用该变量.此技术在MS SQL中不起作用,因为它不允许在SELECT中分配变量,而SELECT也返回数据.它可能也不适用于其他版本的SQL.通常的方法是生成偏移连接,其中连接返回前一行的值,但这可能非常慢.
也就是说,这是在MySQL中实现它的一种方法:
SELECT
sensor_time,
time_diff,
TIME_TO_SEC(time_diff) > 30 AS alarm
FROM (
SELECT
sensor_time,
TIMEDIFF(sensor_time, @prev_sensor_time) AS time_diff,
@prev_sensor_time := sensor_time AS prev_sensor_time
FROM sensor_table,
(SELECT @prev_sensor_time := NULL) AS vars
ORDER BY sensor_time ASC
) AS tmp;
+---------------------+-----------+-------+
| sensor_time | time_diff | alarm |
+---------------------+-----------+-------+
| 2009-09-28 07:08:12 | NULL | NULL |
| 2009-09-28 07:08:40 | 00:00:28 | 0 |
| 2009-09-28 07:09:10 | 00:00:30 | 0 |
| 2009-09-28 07:09:40 | 00:00:30 | 0 |
| 2009-09-28 07:10:10 | 00:00:30 | 0 |
| 2009-09-28 07:10:40 | 00:00:30 | 0 |
| 2009-09-28 07:41:10 | 00:30:30 | 1 |
| 2009-09-28 07:41:40 | 00:00:30 | 0 |
| 2009-09-28 07:42:10 | 00:00:30 | 0 |
| 2009-09-28 07:42:40 | 00:00:30 | 0 |
+---------------------+-----------+-------+
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
4757 次 |
| 最近记录: |