Heim > Datenbank > MySQL-Tutorial > Hauptteil

Wie berechnet man den Zeitunterschied zwischen aufeinanderfolgenden Datensätzen in einer Tabelle?

Patricia Arquette
Freigeben: 2024-11-19 16:10:03
Original
690 Leute haben es durchsucht

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

Berechnung der Zeitdifferenz zwischen aufeinanderfolgenden Datensätzen

Die Aufgabe besteht darin, die Zeitdifferenz zwischen benachbarten Zeilen in einer Tabelle mit einer StartDate-Spalte zu bestimmen. Bei einer gegebenen Tabellenstruktur ist es notwendig, die zeitliche Lücke zwischen jedem Paar aufeinanderfolgender Zeilen zu berechnen.

Ein Ansatz beinhaltet einen Self-Join auf der MyTable. Dies wird durch die folgende Abfrage erreicht:

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
Nach dem Login kopieren

Diese Methode berechnet erfolgreich den Zeitunterschied zwischen aufeinanderfolgenden Datensätzen. Wenn die Anforderungs-IDs jedoch nicht aufeinanderfolgend sind, kann die folgende Abfrage verwendet werden:

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
Nach dem Login kopieren

Durch die Verwendung von CROSS JOIN und einer Unterabfrage identifiziert dieser Ansatz die minimale Anforderungs-ID, die größer als die aktuelle Anforderungs-ID ist , wodurch die Berechnung des Zeitunterschieds auch für nicht aufeinanderfolgende Datensätze möglich ist.

Das obige ist der detaillierte Inhalt vonWie berechnet man den Zeitunterschied zwischen aufeinanderfolgenden Datensätzen in einer Tabelle?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage