如何計算表中連續記錄之間的時間差?

Patricia Arquette
發布: 2024-11-19 16:10:03
原創
690 人瀏覽過

How to Calculate Time Difference Between Consecutive Records in a Table?

計算連續記錄之間的時間差

任務是決定具有 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中文網其他相關文章!

來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板