gpt4 book ai didi

mysql - 查找 mysql 数据库中不同行的时间戳之间的重叠,按天数和 ID 分组

转载 作者:太空宇宙 更新时间:2023-11-03 11:01:45 26 4
gpt4 key购买 nike

我有一张表,其中列出了某些对象的事件。

有两个事件:“移动”和“加载”。它们可以开始也可以结束,并且这些事件在发生时带有时间戳。

通过以下请求,我可以获得以下值:

sum of time, when movement took place (value in the fiddle: 421)
sum of time, when load took place (value in the fiddle: 520)
sum of time, when movement and load took place (value in the fiddle: 391)

当前版本每天计算这些数字,效果很好。

http://sqlfiddle.com/#!2/518dd/1

但我也会有不同的 ID。我现在想为每一天和每个 ID 计算这些数字。当我添加这些数据时,它崩溃了,请看这个 fiddle :

http://sqlfiddle.com/#!2/b43fa/6

这不是这个问题的重复:Find intersections between rows and timestamps in a mysql db ,因为这个问题的解决方案在这种情况下不合适/不适应。

最佳答案

如 Gordon 所示,通过将过滤移动到最外层的 SELECT 可以实现分组。搜索需要包含移动事件的加载事件的方式与 earlier answer 中的方式相同。 :

SELECT id,
date(timestamp, 'unixepoch') AS date,
(SUM(CASE WHEN event = 'movement end' THEN timestamp END) -
SUM(CASE WHEN event = 'movement start' THEN timestamp END)
) AS all_movement,
(SUM(CASE WHEN event = 'load end' THEN timestamp END) -
SUM(CASE WHEN event = 'load start' THEN timestamp END)
) AS all_load,
(SUM(CASE WHEN event = 'movement end' AND
(SELECT event
FROM Table1 b
WHERE timestamp = (SELECT MIN(timestamp)
FROM Table1 c
WHERE c.timestamp >= a.timestamp
AND c.id = a.id
AND c.event LIKE 'load %')
AND b.id = a.id
AND b.event LIKE 'load %'
) = 'load end'
THEN timestamp END) -
SUM(CASE WHEN event = 'movement start' AND
(SELECT event
FROM Table1 b
WHERE timestamp = (SELECT MAX(timestamp)
FROM Table1 c
WHERE c.timestamp <= a.timestamp
AND c.id = a.id
AND c.event LIKE 'load %')
AND b.id = a.id
AND b.event LIKE 'load %'
) = 'load start'
THEN timestamp END)
) AS load_movement
FROM Table1 a
GROUP BY id,
date(timestamp, 'unixepoch')

关于mysql - 查找 mysql 数据库中不同行的时间戳之间的重叠,按天数和 ID 分组,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15114811/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com