Einzelnen Beitrag anzeigen

Slipstream
(Gast)

n/a Beiträge
 
#4

AW: TDBCheckBox: .Checked aktualisiert das DataSet nicht

  Alt 10. Feb 2017, 08:40
Hallo,
wie der Titel schon sagt, folgendes Szenario:

ClientDataSet -> DataSource -> DBCheckBox

Markiere ich selbst die CheckBox, wird das ClientDataSet korrekt aktualisiert,
mache ich das per Code CB.Checked := True, passiert nichts.

Ist das so gewünscht oder ein Bug der VCL?
Wenn du in ein DB-Aware-Komponente eine Änderung machst, wird automatisch das zugeordneten Datasets (oder TQuery oder TTable) in den Modus dsEdit versetzt: MyQuery.State := dsEdit;

Sobald der Datensatzzeiger danach wieder bewegt wird, löst das automatisch ein MyQuery.Post aus, ansonsten muss man das Post selbst ausführen.

Bei Checkboxen, die mit Boolean-Feldern in der Datenbank zusammenhängen, verwenden wir nur selten die DBCheckBox, weil die nicht automatisch auf Änderungen reagiert, sondern sich auf die im zugrundeliegenden Query befindliche Datenmenge bezieht. Am besten, so finde ich, fährt man, wenn man für alle im Programm vorkommenden Datenbank-Zugriffe entsprechende Methoden schreibt, die direkt SQL-Befehle an die Datenbank schicken und entsprechende Aktualisierungsbefehle ausführen (Refresh).
  Mit Zitat antworten Zitat