Forum: PC-Programmierung SQL-select, Zeitstempel


von Firebird (Gast)


Lesenswert?

Hallo Forum,

ein µC-System loggt in einer Firebird-Datenbank minütlich, aber zu 
unterschiedlichen Sekunden (zur Verteilung der Prozessorlast) in 
verschiedenen Tabellen Prozesswerte.

Hierbei enthält jede Tabelle eine Spalte "Zeitstempel", die mit "now" 
durch Firebird gefüllt wird. Also ein Zeitstempel wie "23.11.2012, 
10:25:00.123".

Wie würde eine Abfrage aussehen, die die "zusammengehörigen" Werte aller 
Tabellen in einer neuen Tabelle vereint, wobei der Zeitstempel auf die 
Minutenauflösung heruntergebrochen wird.
Zusammengehörig sollen alle Einträge sein, die in der selben Minute 
stattfinden (also, die Sekunden und tausendstel ignoriert)

Ziel ist eine Tabelle wie:

Zeitstempel | Tabelle1.Werte ... | Tabelle2.Werte ... | Tabelle3.Werte 
...
23.11.2012, 10:25 | ....


meine Versuche mit LIKE und Wildcards in der Spalte "Zeitstempel" 
brachten keine Ergebnisse.

Dank im Vorraus

von D. I. (Gast)


Lesenswert?

SELECT * FROM table WHERE FLOOR(UNIX_TIMESTAMP(Zeitstempel)/60) = 
gesuchte_minute

Diese Anfrage gibt dir alle Tupel deren Minute einer bestimmten Minute 
entspricht.

Sorry habe das Firebird überlesen, aber da sollte es ähnliche Funktionen 
geben.

von Jens G. (jensig)


Lesenswert?

Und wenn die Daten wirklich in mehreren Tabellen existieren, die 
zusammengezogen werden sollen, dann macht man das mit einem 
UNION-Konstrukt:

SELECT * FROM table1 WHERE FLOOR(UNIX_TIMESTAMP(Zeitstempel)/60) =
gesuchte_minute
union all
SELECT * FROM table2 WHERE FLOOR(UNIX_TIMESTAMP(Zeitstempel)/60) =
gesuchte_minute
union all
SELECT * FROM table3 WHERE FLOOR(UNIX_TIMESTAMP(Zeitstempel)/60) =
gesuchte_minute
...
..
.

Ob das mit Firebird so funktioniert, sei erstmal dahingestellt.

von Markus V. (dr-greed)


Lesenswert?

Wenn aus den zu einer Minute gehörenden Werte die Summe  Durchschnitt  
Min / Max berechnet werden soll, bietet sich auch ein GROUP BY an

Bitte melde dich an um einen Beitrag zu schreiben. Anmeldung ist kostenlos und dauert nur eine Minute.
Bestehender Account
Schon ein Account bei Google/GoogleMail? Keine Anmeldung erforderlich!
Mit Google-Account einloggen
Noch kein Account? Hier anmelden.