Delphi-PRAXiS

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Datenbanken (https://www.delphipraxis.net/15-datenbanken/)
-   -   Delphi Datensatz mit nächstem Datensatz vergleichen (https://www.delphipraxis.net/195039-datensatz-mit-naechstem-datensatz-vergleichen.html)

Luca Haas 29. Jan 2018 09:08

Datenbank: MSSQL • Version: ? • Zugriff über: TADO Query

Datensatz mit nächstem Datensatz vergleichen
 
Hi Leute, habe mal eine Frage
Ist es möglich einen Datensatz, mit dem nächsten Datensatz zu vergleichen ?
Also ich habe einen Wert, der bei beiden Datensätzen gleich sein soll, damit ich weiß, dass diese zusammen gehören.
Sollten die beiden nicht zusammen gehören, passiert nichts und das sollte ich ja hinkriegen :laugh: ,aber keine Ahnung ob / wie man die vergleichen kann.

Jasocul 29. Jan 2018 09:28

AW: Datensatz mit nächstem Datensatz vergleichen
 
Zunächst muss geklärt werden, was "der nächste Datensatz" bedeutet.
In der Regel sollte schon das zugehörige SQL-Statement dafür sorgen, dass nur zusammengehörige Datensätze ausgewählt werden.

Ohne die genaue Problemstellung zu kennen, könntest du dir den Inhalt des Vergleichsfeldes merken, dann ein Next des DataSets ausführen. Jetzt könntest du die Werte vergleichen und mit Prev wieder auf den alten Datensatz zurück gehen.

Ob das für dein Problem der richtige Weg ist, kann ich so nicht sagen. Insbesondere kann der Weg falsch sein, wenn der aktuelle Datensatz in Bearbeitung ist oder die Sachen für den Anwender sichtbar sind. Wobei man mit DisableControls und EnableControls die Springerei zwischen den Datensätzen "unsichtbar" machen könnte.

Aber ich denke, dass du vielleicht deine Zielsetzung genauer formulieren solltest. Dann kann man dir vielleicht bessere Tipps geben.

Luca Haas 29. Jan 2018 10:25

AW: Datensatz mit nächstem Datensatz vergleichen
 
Okay, danke für den Tipp, habs zu spät gesehen und auf eigene Faust gemacht.
Ich habe einfach die zu überprüfenden Werte in Variablen zwischengespeichert und diese dann mithilfe von Table1.next mit dem nächsten Datensatz verglichen.

jobo 29. Jan 2018 10:30

AW: Datensatz mit nächstem Datensatz vergleichen
 
Diese Art Vergleiche sind systembedingt natürlich nur unter einer gegebenen Sortierung brauchbar, auf Datasetebene.
Geänderte Sortierung, keine explizite Sortierung, unzureichende Sortierung (zu wenig Spalten, die zu vergleichenden eingeschlossen) können zu Problemen führen, Ebenso eine Visualisierung (jenseits des Dataset) mit anderer Reihenfolge oder ein veralteter Datenstand im Dataset.

p80286 29. Jan 2018 15:10

AW: Datensatz mit nächstem Datensatz vergleichen
 
Ich will hier die Anmerkungen aus #2 und #4 nicht wiederkäuen darum nur ein kurze Anmerkung:
Ich gehe davon aus, daß die Datensätze, die Du erhälst, das Ergebnis einer Query sind. Warum die Qery nicht gleich richtig aufsetzen?
SQL-Code:
select * from .....
where feldvergleich=meinwert
Sollte da mehr als ein Datensatz zurück geliefert werden, mußt du diese Rückgabemenge bearbeiten.

Ansonsten ist der "nächste Datensatz" in Bezug auf Inhalte einer Datenbank eine eher suboptimale Beschreibung.
Erst mit der Kenntnis der verwendeten Abfrage, und ggf. der voreingestellten Eigenschaften der DB läßt sich feststellen wie die Reihenfolge von Datensätzen festgelegt wurde.

Gruß
K-H


Alle Zeitangaben in WEZ +1. Es ist jetzt 23:11 Uhr.

Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz