![]() |
AW: dbCheckbox und dbGrid mit Abfrage
Das glaube ich auch. Ein Klick auf die Checkbox löst eine Änderung des Feldes in der Datenbank aus. Hierfür wird ein SQL Statement benötigt, welches dies tut:
SQL-Code:
UPDATE TABELLE
SET FELD = :FELD WHERE ID = :Old_ID; |
AW: dbCheckbox und dbGrid mit Abfrage
Zitat:
Zitat:
Eine IBQuery kann Daten nur lesen. Zum Ändern ist sie zu blöd. Daher musst Du ihr sagen, wie sie Daten zu ändern, einzufügen oder zu löschen hat. Andere RDBMS können das (meist) von alleine. FB anscheinend nicht. |
AW: dbCheckbox und dbGrid mit Abfrage
Zitat:
|
AW: dbCheckbox und dbGrid mit Abfrage
Du hast bisher mit keinem Wort erwähnt, das man die Daten generell nicht ändern kann, vermutlich, weil Dir das noch nicht einmal aufgefallen ist. Und ich wollte damit nur zum Ausdruck bringen, das es nicht an der Checkbox liegt und das man das Problem mit einer TIBTable lösen kann. Sofort und ohne Umwege. Daher liegt es an etwas, was ein TIBDataset und eine TIBQuery nicht kann, ein TIBTable aber schon.
|
AW: dbCheckbox und dbGrid mit Abfrage
Zitat:
Ich befürchte nur, daß auch dieser einleuchtende Weg keine Änderung des Problems bringt, weil die Checkbox keine Zustandsänderung erlaubt. Zitat:
|
AW: dbCheckbox und dbGrid mit Abfrage
Zitat:
Eigentlich steht doch alles da. TIBUpdateSQL, ModifySQL usw. Google gibt es auch noch: "TIBQuery readonly". |
AW: dbCheckbox und dbGrid mit Abfrage
Also IBTable, soweit hab ich es mittlerweile herausgefunden, ist eine Komponente die den Umstieg von BDE auf SQL-Datenbanksysteme erleichtern soll. Worin allerdings die Fähigkeit bestehen soll das anstehende Problem zu lösen ist mir unverständlich.
|
AW: dbCheckbox und dbGrid mit Abfrage
Bei Verwendung der IBTable wird das benötigte Update-Statement automatisch erzeugt. Dann funktioniert es!
Als Alternative kann man beim IBDataSet bzw. im UpdateObject eines IBQuery das Staement händisch eintragen. In allen Fällen funktioniert die Checkbox dann! |
AW: dbCheckbox und dbGrid mit Abfrage
Ich habe mich für IBDataset entschieden. Daraufhin ein Checkbox click event erzeugt. Mit der IBCheckbox verknüpft, kompiliert(funktioniert), und jetzt bekomme ich mehrere Fehlermeldungen. Achso, mittlerweile liegt zu Versuchszwecken ein zweites Dataset auf der Form.
Delphi-Quellcode:
Nach Aufruf des Abfrageclicks erscheint Fehlermeldung Stackoverflow. Mit F7 durchgeklickt wurde schnell klar, der Checkbox1Click wird bereits aufgerufen bevor der Abfrageclick beendet wird. in der Datenbank sind 15 Datensätze, das CheckboxClick event wurde 15 mal aufgerufen.
procedure TForm1.AbfrageClick(Sender: TObject);
begin with IBDataSet1 do begin Active := False; SelectSQL.Clear; SelectSQL.Text :=('Select * from Tabelle '); Active := True; end; end; procedure TForm1.DBCheckBox1Click(Sender: TObject); begin if DBCheckBox1.Checked = true then begin with IBDataSet1 do begin Close; ModifySQL.Clear; ModifySQL.Text :=('UPDATE Tabelle SET FELD = :FELD WHERE ID = :ID1'); Open; end; end; end; Mit IBDataset2 im Checkboxclick event erscheint Fehlermeldung EmptySQL. Also langsam verzweifele ich. :pale: |
AW: dbCheckbox und dbGrid mit Abfrage
Die onClick-Methode ist unnötig
Delphi-Quellcode:
procedure TForm1.AbfrageClick(Sender: TObject);
begin IBDataSet1.SelectSQL.Text :='Select * from Tabelle;'; iBDataSet1.ModifySQL.Text := 'UPDATE Tabelle SET FELD = :FELD WHERE ID = :old_ID;'; IBDataSet1.Open; end; |
Alle Zeitangaben in WEZ +1. Es ist jetzt 11:32 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-2025 by Thomas Breitkreuz