2011-10-29 199 views
16

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

谢谢。


@马克拜尔斯和@叶海亚,我请求表作为的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等。我知道我需要桌上的自我加入,但我没有得到正确的条款。

+4

连续?你能举一个你想要的例子吗? –

回答

21

为了达到你所要求的请尝试以下(从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 

IF 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 
3

接受的答案是正确的,但给出数字的区别。 作为一个例子,如果我有以下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 
根据什么领域
相关问题