sql >> Databáze >  >> RDS >> Mysql

Vypočítejte časový rozdíl mezi dvěma řádky

Chcete-li dosáhnout toho, co požadujete, zkuste následující (UPDATE po úpravě z 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

POKUD requestid není po sobě jdoucí, pak můžete použít

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


  1. Spustit spouštěč při aktualizaci sloupce A nebo ColumnB nebo ColumnC

  2. Najmout nebo najmout:Datový model pro proces náboru

  3. Jak vytvořit skutečný vztah jeden k jednomu na serveru SQL Server

  4. MySQL JOIN pouze k nejnovějšímu řádku?