![]() |
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? |
AW: Wie erhalte Ich die Änderungen eines TClientDataset in ein TClientDataset um dies
Die Zuweisung
Delphi-Quellcode:
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.
DatasetArtikel.Data := Self.DatasetArtikel.Delta;
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. |
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 :/ ... |
AW: Wie erhalte Ich die Änderungen eines TClientDataset in ein TClientDataset um dies
Zitat:
|
AW: Wie erhalte Ich die Änderungen eines TClientDataset in ein TClientDataset um dies
Ich verwende XE6 ...
|
AW: Wie erhalte Ich die Änderungen eines TClientDataset in ein TClientDataset um dies
Zitat:
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:
Eventuell klingt TClientDataSet.LogChanges nach einer praktischen Sache? |
AW: Wie erhalte Ich die Änderungen eines TClientDataset in ein TClientDataset um dies
Zitat:
Hast du eventuell andere Units eingebunden, in denen usModified auch deklariert ist? |
AW: Wie erhalte Ich die Änderungen eines TClientDataset in ein TClientDataset um dies
Zitat:
Delphi-Quellcode:
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.
false
|
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? |
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. |
AW: Wie erhalte Ich die Änderungen eines TClientDataset in ein TClientDataset um dies
Hast du schon mal versucht, im ClientDataSet die Methode
Delphi-Quellcode:
aufzurufen? Die sollte nämlich genau das tun, was du hier umständlich von Hand nachzubilden versuchst.
ApplyUpdates
|
AW: Wie erhalte Ich die Änderungen eines TClientDataset in ein TClientDataset um dies
Komisch, das war
![]() |
AW: Wie erhalte Ich die Änderungen eines TClientDataset in ein TClientDataset um dies
Zitat:
|
AW: Wie erhalte Ich die Änderungen eines TClientDataset in ein TClientDataset um dies
Theorie und Praxis sind leider nicht immer identisch.
|
AW: Wie erhalte Ich die Änderungen eines TClientDataset in ein TClientDataset um dies
Hier ist noch einer:
![]() |
AW: Wie erhalte Ich die Änderungen eines TClientDataset in ein TClientDataset um dies
Interessant, so macht man sich auf Dauer aber keine Freunde. Nichts gegen Crossposts an sich, aber Verlinkungen untereinander sollten schon sein.
|
Alle Zeitangaben in WEZ +1. Es ist jetzt 22:01 Uhr. |
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz