计算两行之间的时间差

Posted

技术标签:

【中文标题】计算两行之间的时间差【英文标题】:Calculate the time difference between of two rows 【发布时间】:2011-10-29 06:03:06 【问题描述】:

我有一个包含 StartDate 列的表,我想计算两个连续记录之间的时间差。

谢谢。


@Mark Byers 和@Yahia,我的请求表为 requestId,startdate

requestId    startdate               
1            2011-10-16 13:15:56
2            2011-10-16 13:15:59
3            2011-10-16 13:15:59
4            2011-10-16 13:16:02
5            2011-10-16 13:18:07

我想知道 requestid 1 和 2、2 和 3、3 和 4 等之间的时差是多少。我知道我需要在表上自我加入,但我在子句上没有得到正确的结果。

【问题讨论】:

连续按什么字段?你能举一个你想要的例子吗? 【参考方案1】:

要实现您的要求,请尝试以下操作(从 OP 编辑​​后更新):

SELECT A.requestid, A.starttime, (B.starttime - A.starttime) AS timedifference
FROM MyTable A INNER JOIN MyTable B ON B.requestid = (A.requestid + 1)
ORDER BY A.requestid ASC

如果requestid不连续,则可以使用

SELECT A.requestid, A.starttime, (B.starttime - A.starttime) AS timedifference
FROM MyTable A CROSS JOIN MyTable B
WHERE B.requestid IN (SELECT MIN (C.requestid) FROM MyTable C WHERE C.requestid > A.requestid)
ORDER BY A.requestid ASC

【讨论】:

第二个目的可以写成starttime而不是requestid!!【参考方案2】:

接受的答案是正确的,但给出了数字的差异。 例如,如果我有以下 2 个时间戳

2014-06-09 09:48:15
2014-06-09 09:50:11

差值为 196。这只是 5011 - 4815。 为了得到时差,你可以修改脚本如下:

SELECT A.requestid, A.starttime, TIMESTAMPDIFF(MINUTE,A.starttime,B.starttime) AS timedifference 
FROM MyTable A INNER JOIN MyTable B ON B.requestid = (A.requestid + 1) 
ORDER BY A.requestid ASC

【讨论】:

【参考方案3】:
SELECT TIMESTAMPDIFF(SECOND, grd.startdate, grd1.startdate) as TD FROM myTable A 
inner join myTable B on A.requestId = B.requestId - 1 and 
A.startdate >= '2019-07-01' order by TD desc

【讨论】:

以上是关于计算两行之间的时间差的主要内容,如果未能解决你的问题,请参考以下文章

如何选择每组的前两行并在一列中计算它们之间的差异?

在laravel中计算两行的时间差

计算两个不相邻行之间的差异

在 Open Office Calc 中计算行之间的相同值

如何搜索与SQL两行之间寻找日期时间?

25:计算两个日期之间的天数