Hallo Erik,
ich bin kein SQL Experte, aber bei großen Tabellen kann es evtl.
schneller sein, wenn du mit den richtigen indices arbeitest. Ich kenne
mich mit MariaDB nicht aus, aber da kann man sich sicher auch mit
EXPLAIN anschauen, was die query macht und dann optimieren.
Ansonsten einfach die Werte der beiden neuesten Zeilen im PHP
subtrahieren, aber das war ja nicht die Frage ;)
VG
Sebastian
Am 19.02.22 um 13:52 schrieb Erik Schanze:
Hallo Sebastian,
vielen Dank für deine schnelle Antwort. Das Kommando funktioniert, aber
dauert sehr lange:
MariaDB [siemens]> SELECT TIMESTAMPDIFF(SECOND, created, LEAD(created) OVER
(ORDER BY created DESC)) AS diff FROM log1 ORDER BY
created DESC LIMIT 1;
+------+
| diff |
+------+
| -121 |
+------+
1 row in set (1 min 5.042 sec)
Da kann ich die beiden Zeitstempel deutlich schneller in PHP (wo das SQL
benutzt wird) subtrahieren.
VG,
Erik
Am 19.02.22 um 13:29 schrieb Sebastian Weckend:
Hallo Erik,
schau dir mal die window functions [0], besonders LEAD [1] und LAG [2]
an.
Wenn der Datentyp von created TIMESTAMP ist und du nur den Unterschied
der beiden neuesten Zeilen in der DB möchtest, dann so was ähnliches
wie (ungetestet):
SELECT
TIMESTAMPDIFF(SECOND, created, LEAD(created) OVER (ORDER BY
created DESC)) AS diff
FROM table
ORDER BY created DESC
LIMIT 1;
Viele Grüße
Sebastian
[0] https://mariadb.com/kb/en/window-functions/
[1] https://mariadb.com/kb/en/lead/
[2] https://mariadb.com/kb/en/lag/
Am 19.02.22 um 12:14 schrieb Erik Schanze:
Liebe Linux-User,
ich habe eine MariaDB auf Debian 11 laufen und möchte die Zeitdifferenz
in Sekunden zwischen der letzten und der vorletzten Zeile in einer
Tabelle haben, anhand des "created"-Wertes. Die Beispiele im Internet
ufern irgendwie immer gleich derart aus, dass ich sie nicht mehr
verstehe. Ich habe nur rudimentäres SQL-Wissen. :-)
Gibt es da kein einfache Abfrage, die ich nur nicht gefunden habe?
Ich freue mich auf eure Antworten.
VG,
Erik