AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken dbCheckbox und dbGrid mit Abfrage
Thema durchsuchen
Ansicht
Themen-Optionen

dbCheckbox und dbGrid mit Abfrage

Ein Thema von blutigerAnfänger · begonnen am 2. Aug 2014 · letzter Beitrag vom 3. Okt 2014
Antwort Antwort
blutigerAnfänger

Registriert seit: 23. Mär 2010
82 Beiträge
 
#1

AW: dbCheckbox und dbGrid mit Abfrage

  Alt 3. Sep 2014, 09:11
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.
Aufgefallen ist es mir schon, ich ging bloß davon aus, daß der Inhalt der Tabelle unabänderlich ist. Und die Änderung des Checkboxzustandes innerhalb der Checkbox abläuft, bis diese Änderung der Tabelle (über Update im Click event) mitgeteilt wird. Das ist ja auch der Weg von mkinzler, wenn ich das richtig verstanden habe.
Ich befürchte nur, daß auch dieser einleuchtende Weg keine Änderung des Problems bringt, weil die Checkbox keine Zustandsänderung erlaubt.

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.
Du machst mich neugierig und läßt mich verhungern??
  Mit Zitat antworten Zitat
Dejan Vu
(Gast)

n/a Beiträge
 
#2

AW: dbCheckbox und dbGrid mit Abfrage

  Alt 3. Sep 2014, 09:19
Du machst mich neugierig und läßt mich verhungern??
Huuhhaaahar.
Eigentlich steht doch alles da. TIBUpdateSQL, ModifySQL usw. Google gibt es auch noch: "TIBQuery readonly".
  Mit Zitat antworten Zitat
blutigerAnfänger

Registriert seit: 23. Mär 2010
82 Beiträge
 
#3

AW: dbCheckbox und dbGrid mit Abfrage

  Alt 3. Sep 2014, 15:58
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.
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

Registriert seit: 9. Dez 2005
Ort: Heilbronn
39.876 Beiträge
 
Delphi 11 Alexandria
 
#4

AW: dbCheckbox und dbGrid mit Abfrage

  Alt 3. Sep 2014, 16:05
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!
Markus Kinzler
  Mit Zitat antworten Zitat
blutigerAnfänger

Registriert seit: 23. Mär 2010
82 Beiträge
 
#5

AW: dbCheckbox und dbGrid mit Abfrage

  Alt 4. Sep 2014, 19:45
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:
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;
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.

Mit IBDataset2 im Checkboxclick event erscheint Fehlermeldung EmptySQL.

Also langsam verzweifele ich.
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

Registriert seit: 9. Dez 2005
Ort: Heilbronn
39.876 Beiträge
 
Delphi 11 Alexandria
 
#6

AW: dbCheckbox und dbGrid mit Abfrage

  Alt 4. Sep 2014, 20:11
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;
Markus Kinzler
  Mit Zitat antworten Zitat
blutigerAnfänger

Registriert seit: 23. Mär 2010
82 Beiträge
 
#7

AW: dbCheckbox und dbGrid mit Abfrage

  Alt 4. Sep 2014, 20:32
Verdammt schwer zu begreifen, daß es keinen ClickEvent für Checkbox geben soll, da es ja erst beim Drücken auf die Checkbox eine Änderung geben sollte.
  Mit Zitat antworten Zitat
blutigerAnfänger

Registriert seit: 23. Mär 2010
82 Beiträge
 
#8

AW: dbCheckbox und dbGrid mit Abfrage

  Alt 1. Okt 2014, 16:20
Es funktioniert. Danke, daß ihr Euch die Köpfe zerbrochen habt.
Und woran hat's jetzt gelegen?
Ich wollt, ich wüßte es.

Eigentlich wollte ich die Abfrage jetzt selber schreiben, denn bisher habe ich ja nur die gesamte Tabelle abgefragt.

Delphi-Quellcode:
procedure TForm1.AbfrageClick(Sender: TObject);
begin
    IBDataSet1.SelectSQL.Text :='Select * from Tabelle;';
    IBDataSet1.Open;
end;
Doch da stimmt etwas nicht.
Delphi-Quellcode:
procedure TForm1.AbfrageClick(Sender: TObject);
begin
StringNAME := '____';
StringBEZEICHNUNG := '%';
  with IBDataSet1 do
    begin
      Active:=False;
      SelectSQL.Clear;
      SelectSQL.Add('Select * from Tabelle2 where NAME Like :text1 ');
      SelectSQL.Add('And Upper (BEZEICHNUNG) Like Upper (:text2) ');
      ParamByName('text1').asString := StringNAME;
      ParamByName('text2').asString := StringBEZEICHNUNG;
      Active:=True;
    end;
end;
Hiermit frage ich alle Datensätze, welche 4 Buchstaben haben, ab.
In der gesamten Tabelle2 sind einige tausend Treffer vorhanden, angezeigt werden 0, Null, nichts, gar nichts.
Ersetze ich die vier Unterstriche in StringNAME durch ein Prozentzeichen funktioniert die Abfrage, allerdings werden auch alle Datensätze angezeigt.
In der Vorversion dieses Programms hat doch noch alles funktioniert. Dort hatte ich nur die Felder Name und Bezeichnung. Hier sind es ja noch die Felder Combobox, und das ID Feld.
Woran liegt das?
Achso In der Vorversion war es eine Query.
  Mit Zitat antworten Zitat
Benutzerbild von Sir Rufo
Sir Rufo

Registriert seit: 5. Jan 2005
Ort: Stadthagen
9.454 Beiträge
 
Delphi 10 Seattle Enterprise
 
#9

AW: dbCheckbox und dbGrid mit Abfrage

  Alt 4. Sep 2014, 20:20
Ich wiederhole jetzt nochmal, was hier schon mehrmals gesagt wurde:

Die Checkbox bekommt keinen OnClick-Event zugewiesen.

Dem IBDataSet1 werden die Eigenschaften fürzugewiesen (das sind die SQL-Statements)

Jetzt wird die einfach geöffnet und durch den Klick auf die CheckBox bekommt das DataSet diese Änderung automatisch (d.h. ohne irgendwelchen sonstigen Code von wem auch immer) mit und wird auch an die Datenbank zurückgeschrieben (ja, weil wir ja das ModifySQL angegeben haben).
Kaum macht man's richtig - schon funktioniert's
Zertifikat: Sir Rufo (Fingerprint: ‎ea 0a 4c 14 0d b6 3a a4 c1 c5 b9 dc 90 9d f0 e9 de 13 da 60)
  Mit Zitat antworten Zitat
blutigerAnfänger

Registriert seit: 23. Mär 2010
82 Beiträge
 
#10

AW: dbCheckbox und dbGrid mit Abfrage

  Alt 2. Okt 2014, 12:04
Schade, daß keiner helfen kann.
  Mit Zitat antworten Zitat
Antwort Antwort


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 04:04 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