![]() |
Re: TEdit mit DBEdit?
Zitat:
|
Re: TEdit mit DBEdit?
Hast du meinen source-code heute früh nicht erhalten?
ja, die Query sieht so aus...:
Delphi-Quellcode:
Nachtrag:
ADOQuery1.SQL.Text :=
'SELECT Mitgliedsnummer, Vorname, Name, Strasse, Land, PLZ, Ort, ' + 'Tel_1, Fax_1, Tel_2, Fax_2, Handy, email, ' + 'GebDat, ' + 'Saldo, ' + 'Eintritt, ' + 'Spielernummer, Trikot, Spielerposition.Spielerpos FROM ' + 'ID, Mitglied, Kontakt, GebDatList, MG_Saldenliste, ' + 'Mitgliedsstatus, Spielerdaten, Spielerposition ' + 'WHERE Mitglied.ID=Kontakt.ID AND Kontakt.ID=GebDatList.ID AND ' + 'GebDatList.ID=MG_Saldenliste.ID AND MG_Saldenliste.ID=Mitgliedsstatus.ID ' + 'AND Mitgliedsstatus.ID=Spielerdaten.ID AND Spielerdaten.Spielerpos=' + 'Spielerposition.SID'; ...und das zeigt mir der Compiler an. [Hinweis] Mitgliedsdaten.pas(103): Auf 'ds' zugewiesener Wert wird niemals benutzt Scheint so als würde überhaupt nicht auf meinen Code zugegriffen zu werden. Verstehe ich das richtig? |
Re: TEdit mit DBEdit?
* push * :)
|
Re: TEdit mit DBEdit?
kann geschlossen werden.
der fehler lag bei mir, da ich die ereignisse in OnCreate und nicht im OnShow eingetragen hatte. Nun läuft es... Thx für die mithilfe. |
Re: TEdit mit DBEdit?
Also... Sharky hat schon richtig erkannt, dass ich einfach nicht ständig Form1.DataSource1.DataSet im nachfolgenden Code wiederholen wollte! Allerdings ist wohl das Prinzip noch nicht ganz klar... Ausserdem steckt in seinem Codebeispiel ein gaaanz böser Fehler drin: Erst wird eine neue TDataSet-Instanz erzeugt (was hier völlig unnötig ist), dann wird der Objektvariablen ds eine ganz andere Instanz (nämlich Form1.DataSource1.DataSet) zugewiesen. Im finally-Abschnitt wird dann diese andere Instanz zerstört (also Form1.DataSource1.DataSet) und die neu erzeugte Instanz wird überhaupt nicht zerstört (es gibt ja auch keinen Pointer mehr auf diese neue Instanz)... uiuiuiuiuiuiu....
Die richtige Variante sieht so aus:
Delphi-Quellcode:
Du könntest es auch so schreiben, was aber länger und vor allem schlechter wartbar ist:
procedure TForm1.FormShow(Sender: TObject);
var ds : TDataSet; // lokales TDataSet begin ds := Form1.DataSource1.DataSet; Panel1.Caption := Format(' Das sind Daten von %s, %s - %s', [ds['Name'], ds['Vorname'], ds['Mitgliedsnummer']]); { ... } end;
Delphi-Quellcode:
Die Anweisung
procedure TForm1.FormShow(Sender: TObject);
begin Panel1.Caption := Format(' Das sind Daten von %s, %s - %s', [Form1.DataSource1.DataSet['Name'], Form1.DataSource1.DataSet['Vorname'], Form1.DataSource1.DataSet['Mitgliedsnummer'] ]); { ... } end;
Delphi-Quellcode:
musst Du unbedingt aus Deinem Code entfernen! Denn Du erzeugst hier eine neue Instanz, die aber weder benötigt noch verwendet wird (deshalb auch der Compiler-Hinweis "Auf 'ds' zugewiesener Wert wird niemals benutzt") und - was wirklich schlimm ist - niemals freigegeben wird! D.h Du erzeugst bei jedem Aufruf Deines Formulars eine neue TDataSet-Instanz, die dann alle nutzlos ohne Referenz im Speicher rumliegen...
ds := TDataSet.Create(Self);
Wenn Du allerdings tatsächlich eine Objektinstanz erzeugen musst, ist der nachfolgende Zugriff auf diese neue Instanz unbedingt durch einen try-finally-Block zu kapseln (so wie es Sharky schon gezeigt hat):
Delphi-Quellcode:
var
obj1: TMyClass; begin obj1 := TMyClass.Create(); try // Irgendwas mit obj1 machen... finally obj1.Free; end; end; |
Alle Zeitangaben in WEZ +1. Es ist jetzt 06:29 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