Delphi-PRAXiS
Seite 1 von 2  1 2      

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Sonstige Fragen zu Delphi (https://www.delphipraxis.net/19-sonstige-fragen-zu-delphi/)
-   -   Wie erhalte Ich die Änderungen eines TClientDataset in ein TClientDataset um diesen i (https://www.delphipraxis.net/181805-wie-erhalte-ich-die-aenderungen-eines-tclientdataset-ein-tclientdataset-um-diesen-i.html)

omega90 10. Sep 2014 10:03

Wie erhalte Ich die Änderungen eines TClientDataset in ein TClientDataset um diesen i
 
Hallo Zusammen...

Ich habe vor die Daten in einem TClientDataset über ein Grid zu ändern und über Delta die geänderten Daten in einem TClientDataset in einer Schleife zu durchlaufen und den passenden SQL Code zu bauen.

Hierfür greife ich auf eine DBF Datei zu die mir über eine Komponente ApolloDatabase und ApolloTable in mein TClientDataset übergibt. Das funktioniert.

Ich kann die Daten in einem Grid anzeigen lassen via DataSource und Provider. Über folgenden Code prüfe Ich zunächst ob die Daten geändert wurden im TClientDataset.

Quellcode
if Self.DatasetArtikel.ChangeCount = 0 then
begin
ShowMessage('Delta is empty');
Exit;
end;


Anschließend gebe Ich in einem Integer aus wieviele Änderungen es gab.

Quellcode
counter := DatasetArtikel.ChangeCount;


Nun möchte Ich die Änderungen (Nur die Änderungen) im Dataset erfassen.

Quellcode
DatasetArtikel.Data := Self.DatasetArtikel.Delta;


Danach wollte Ich in einer Schleife das Dataset durchlaufen, mir ist jedoch aufgefallen das Ich auch wenn Ich einen Wert geändert hatte nur den alten Wert erhalte.

Zum Beispiel habe Ich in der Spalte 3 im ersten Daensatz blueblue stehen und änder diesen in redred ab. Jedoch bekomme Ich nur blueblue zurück aber ich brauche den neuen Wert..

Quellcode
value := DatasetArtikel.Fields[2].OldValue; //gibt blueblue zurück
value := DatasetArtikel.Fields[2].Value; //gibt blueblue zurück
value := DatasetArtikel.Fields[2].NewValue; //gibt blueblue zurück


Wie kann ich das realisieren das Ich ein Dataset erhalte nur mit den Änderungen und dieses in einer Schleife durchlaufe und die neuen Werte rausfilter?

Uwe Raabe 10. Sep 2014 10:22

AW: Wie erhalte Ich die Änderungen eines TClientDataset in ein TClientDataset um dies
 
Die Zuweisung
Delphi-Quellcode:
DatasetArtikel.Data := Self.DatasetArtikel.Delta;
ist unter der Annahme, daß DatasetArtikel und Self.DatasetArtikel identisch sind, eher fragwürdig, da du damit dem ClientDataSet ja die eigentliche Datenbasis unter dem Hintern wegziehst.

Wenn du nur die geänderten Records des Datasets sehen willst, setz doch einfach

Delphi-Quellcode:
DatasetArtikel.StatusFilter := [usModified];


Vielleicht ist es hier ja nicht relevant, aber das Prinzip kann man auch auf usInserted und usDeleted ausweiten.

omega90 10. Sep 2014 11:00

AW: Wie erhalte Ich die Änderungen eines TClientDataset in ein TClientDataset um dies
 
Ich bekomme aber dann beim Compilieen den Fehler : E2010 Inkompatible Type: TUpdateStatusSet und Set


Ich bin neu in der Arbeit mit diesen TClientDatasets. Im Prinzip möchte Ich ja nicht mehr als nur die Daten aus dem Dataset ändern und wieder zurück spielen in die dbf Datei. Und ja die Arbeit mit dbf Dateien ist veraltet aber der Kunde will das so und so muss das gemacht werden :/ ...

Uwe Raabe 10. Sep 2014 11:03

AW: Wie erhalte Ich die Änderungen eines TClientDataset in ein TClientDataset um dies
 
Zitat:

Zitat von omega90 (Beitrag 1271984)
Ich bekomme aber dann beim Compilieen den Fehler : E2010 Inkompatible Type: TUpdateStatusSet und Set

Welche Delphi-Version?

omega90 10. Sep 2014 11:28

AW: Wie erhalte Ich die Änderungen eines TClientDataset in ein TClientDataset um dies
 
Ich verwende XE6 ...

himitsu 10. Sep 2014 11:56

AW: Wie erhalte Ich die Änderungen eines TClientDataset in ein TClientDataset um dies
 
Zitat:

Zitat von omega90 (Beitrag 1271971)
Delphi-Quellcode:
        value := DatasetArtikel.Fields[2].OldValue; //gibt blueblue zurück
        value := DatasetArtikel.Fields[2].Value; //gibt blueblue zurück
        value := DatasetArtikel.Fields[2].NewValue; //gibt blueblue zurück
Wie kann ich das realisieren das Ich ein Dataset erhalte nur mit den Änderungen und dieses in einer Schleife durchlaufe und die neuen Werte rausfilter?

OldValue sollte nur für den aktuellen Datensatz verfügar sein.
Es wird nicht für alle Datensätze der "alte" Zustand gespeichert. Was ist überhaupt alt? Nja, wenn, dann müsstest du das wohl selber speichern, in eine/mehreren zusätzlichen Spalten oder woanders.

Und das OldValue könnte auch nur während des Inserts/Edits gültig/aktuell sein, bis hin zum nächsten Post/Cancel.


Ob der OldValue auch länger gespeihert wird, ist nicht unbedingt/immer gegeben.
Zitat:

Zitat von OH
Sobald die Datensätze erfolgreich eingetragen wurden, kann der ursprüngliche Feldwert nicht mehr ermittelt werden.

Anmerkung: Die Eigenschaft OldValue kann nur verwendet werden, wenn mit der Komponente TClientDataSet auf die Daten zugegriffen wird oder zwischengespeicherte Aktualisierungen genutzt werden.



Eventuell klingt TClientDataSet.LogChanges nach einer praktischen Sache?

Uwe Raabe 10. Sep 2014 12:18

AW: Wie erhalte Ich die Änderungen eines TClientDataset in ein TClientDataset um dies
 
Zitat:

Zitat von omega90 (Beitrag 1271989)
Ich verwende XE6 ...

Funktioniert hier problemlos!

Hast du eventuell andere Units eingebunden, in denen usModified auch deklariert ist?

Uwe Raabe 10. Sep 2014 12:20

AW: Wie erhalte Ich die Änderungen eines TClientDataset in ein TClientDataset um dies
 
Zitat:

Zitat von himitsu (Beitrag 1271997)
Eventuell klingt TClientDataSet.LogChanges nach einer praktischen Sache?

Wenn das auf
Delphi-Quellcode:
false
stände, gäbe es gar kein Delta. Deswegen ist es ja per default eingeschaltet. Es gibt nur ganz wenige Fälle, wo man das ausschalten sollte.

Uwe Raabe 10. Sep 2014 13:16

AW: Wie erhalte Ich die Änderungen eines TClientDataset in ein TClientDataset um dies
 
Wie verbindest du denn das ClientDataSet mit dem ApolloTable?

Reicht es nicht, einfach einen TDataSetProvider dazwischenzuschalten und dessen ResolveToDataSet auf true zu setzen?

omega90 10. Sep 2014 13:37

AW: Wie erhalte Ich die Änderungen eines TClientDataset in ein TClientDataset um dies
 
Also kurz zur Abfolge meines Projektes:

Ordner mit DBF Dateien (iArtikel.dbf) : -> ApolloDatabase (kdaten) -> ApolloTable (Databasename:kdaten,TableName:iArtikel.dbf) -> TDataSetProvider (Dataset:ApolloTable) -> TClientDataset (Providername: TDatasetProvider) -> TDataSource (Dataset: TClientDataset) -> bindet an Grid


Daten werden im Grid geändert und sollen zurück zurück zur dbf datei...wie Ich das über die apollo komponente machen kann weiss ich ungefähr aber dafür benötige Ich den SQL Befehl und die werte die geändert wurden.


Alle Zeitangaben in WEZ +1. Es ist jetzt 10:35 Uhr.
Seite 1 von 2  1 2      

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