計算連續記錄之間的時間差
任務是決定具有 StartDate 列的表中相鄰行之間的時間差。給定一個表結構,有必要計算每對連續行之間的時間間隙。
一種方法涉及 MyTable 上的自連接。以下查詢可以實現此目的:
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
此方法成功計算連續記錄之間的時間差。但是,如果請求ID 不連續,則可以使用以下查詢:
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
透過利用CROSS JOIN 和子查詢,此方法可識別大於當前請求ID 的最小請求ID ,即使對於非連續記錄也可以計算時間差。
以上是如何計算表中連續記錄之間的時間差?的詳細內容。更多資訊請關注PHP中文網其他相關文章!