H
Harrry
Gast
Hallo,
ich benutze in meinem Projekt Java für die Datenbankkommunikation.
Bei einer Abfrage stell ich mich grad ziemlich doof an und komme nicht auf das Ziel, vielleicht könnte mir von euch jemand Helfen.
Erstmal dein Beispielsszenario, damit ihr versteht um was es geht:
Es sollen die Positionen von bestimmten Gegenständen gespeichert werden. Zu jeder Position werden unter anderem Start- und Endzeitpunkt gespeichert.
Beispiel:
Die Abfrage findet jede Minute statt. Das heißt, hat sich ein Gegenstand nicht bewegt, muss der "bis Zeitpunkt" erneuert werden. Da dies unter Umständen sehr viel Positionen sein können, habe ich mir folgendes überlegt.
Ich erstelle mir immer ein Session-Objekt. In dieses wird jede Minute die aktuelle Zeit eingetragen. Somit habe ich nicht mehr x Updates für x unbewegte Objekte, sondern nur ein Update in der Session-Tabelle.
Wenn sich ein Objekt bewegt, wird in der Position die bis zu diesem Zeitpunkt gültig war der Endzeitpunkt eingetragen und ein neues Positions-Objekt erstellt, der nur die aktuelle Zeit als Start-Zeitpunkt hat aber kein Endzeitpunkt.
Das heißt, es könnte so aussehen
Wird das Programm beendet, wird überall der Zeitpunkt der Beendigung eingetragen.
So weit, so gut.
Wenn das Programm abstürzen sollte oder nicht regulär beendet wurde, sind nach der Beendigung des Programms Positionen mit null-Einträgen vorhanden.
Nun will ich bei jedem Neustart eine Art Repair-Methode durchführen, die bei allen null-Werte im "bis"-Feld der Positions-Tabelle die Zeit der letzten Session einträgt (also im Prinzip einfach das neueste Datum in Session).
Als normale Datenbank-Abfrage wäre dies sehr simpel:
Doch wie macht man dies am geschicktesten über Hibernate?
Einfallen würde mir:
max(bis) von Session abfragen.
alle Objekte von Position rausschreiben lassen, in denen null im "bis"-Feld steht und diese wieder mit dem Wert aus Session updaten.
Das sind mehr SQL-Abfragen als das was ich oben geschrieben habe und damit ineffizienter.
Wie würdet ihr das machen?
Oder würdet ihr ganz anders vorgehen bei dem Problem?
Danke für eure Hilfe
ich benutze in meinem Projekt Java für die Datenbankkommunikation.
Bei einer Abfrage stell ich mich grad ziemlich doof an und komme nicht auf das Ziel, vielleicht könnte mir von euch jemand Helfen.
Erstmal dein Beispielsszenario, damit ihr versteht um was es geht:
Es sollen die Positionen von bestimmten Gegenständen gespeichert werden. Zu jeder Position werden unter anderem Start- und Endzeitpunkt gespeichert.
Beispiel:
Java:
Tabelle: Gegenstände
Spalten: ID, Name, ...
Zeile 1: 0, A
Zeile 2: 1, B
Tabelle: Positionen
Spalten: ID, Gegenstand-ID, Ort, von, bis
Zeile 1: 0, 0, Feld 2, 20:21, 20:45
Zeile 2: 1, 0, Feld 5, 20:45, 21:00
Zeile 3: 2, 0, Feld 1, 21:00, 21:45
Zeile 4: 3, 1, Feld 8, 20:21, 20:30
Zeile 5: 4, 1, Feld 10, 20:30, 21:45
Die Abfrage findet jede Minute statt. Das heißt, hat sich ein Gegenstand nicht bewegt, muss der "bis Zeitpunkt" erneuert werden. Da dies unter Umständen sehr viel Positionen sein können, habe ich mir folgendes überlegt.
Ich erstelle mir immer ein Session-Objekt. In dieses wird jede Minute die aktuelle Zeit eingetragen. Somit habe ich nicht mehr x Updates für x unbewegte Objekte, sondern nur ein Update in der Session-Tabelle.
Wenn sich ein Objekt bewegt, wird in der Position die bis zu diesem Zeitpunkt gültig war der Endzeitpunkt eingetragen und ein neues Positions-Objekt erstellt, der nur die aktuelle Zeit als Start-Zeitpunkt hat aber kein Endzeitpunkt.
Das heißt, es könnte so aussehen
Java:
Tabelle: Session
Spalte: ID, von, bis
Zeile 1: 0, 20:21, 21:60
Tabelle: Positionen
Spalten: ID, Gegenstand-ID, Ort, von, bis
Zeile 6: 5, 0, Feld 11, 21:45, null
Zeile 7: 6, 1, Feld 12, 21:45, null
Wird das Programm beendet, wird überall der Zeitpunkt der Beendigung eingetragen.
So weit, so gut.
Wenn das Programm abstürzen sollte oder nicht regulär beendet wurde, sind nach der Beendigung des Programms Positionen mit null-Einträgen vorhanden.
Nun will ich bei jedem Neustart eine Art Repair-Methode durchführen, die bei allen null-Werte im "bis"-Feld der Positions-Tabelle die Zeit der letzten Session einträgt (also im Prinzip einfach das neueste Datum in Session).
Als normale Datenbank-Abfrage wäre dies sehr simpel:
SQL:
UPDATE Position
SET value = (
SELECT max(bis)
FROM Session
)
WHERE bis IS NULL;
Doch wie macht man dies am geschicktesten über Hibernate?
Einfallen würde mir:
max(bis) von Session abfragen.
alle Objekte von Position rausschreiben lassen, in denen null im "bis"-Feld steht und diese wieder mit dem Wert aus Session updaten.
Das sind mehr SQL-Abfragen als das was ich oben geschrieben habe und damit ineffizienter.
Wie würdet ihr das machen?
Oder würdet ihr ganz anders vorgehen bei dem Problem?
Danke für eure Hilfe