Delphi-PRAXiS
Seite 2 von 2     12   

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Datenbanken (https://www.delphipraxis.net/15-datenbanken/)
-   -   Problem mit myQuery (https://www.delphipraxis.net/211739-problem-mit-myquery.html)

lucy 7. Nov 2022 11:06

AW: Problem mit myQuery
 
Zitat:

"anzahl" ist lokal deklariert. Der Vergleich (if) wird also immer mit einer nicht initialisierten Variablen gemacht. Der Vergleich wird daher eher zufällige Ergebnisse liefern und dein Label auch nur zufällig aktualisiert.
ja richtig, mal wieder ein brett vorm kopf! danke

himitsu 7. Nov 2022 11:40

AW: Problem mit myQuery
 
Wobei das ja eigentlich der Compiler dir auch gesagt haben müsste, vonwegen "nicht-initialisierte Variable".



Und natürlich das fehlende
Delphi-Quellcode:
count.Refresh;
im Timer, falls es nicht woanders schon gemacht wird.
Wobei, würde es woanders gemacht, wozu dann der Timer und nicht direkt dort auf die Änderung prüfen?

lucy 7. Nov 2022 11:44

AW: Problem mit myQuery
 
hier mein Lösungsweg:

Delphi-Quellcode:
procedure TForm1.pruefenTimer(Sender: TObject);
 var anzahl, i: integer;
             s: String;
begin
  count.Refresh;
   anzahl:= count.Fields[0].AsInteger;
  if anzahl <> i then
   begin
    i := anzahl;
     Label2.Caption := 'Anzahl Datensätze : '+ InttoStr(i);
  end
end;

oder kann man es noch etwas eleganter lösen?

mein Ziel ist es (noch nicht fertig) das DBGrid wirklich nur zu aktualisieren wenn neue Daten dazugekommen sind.

lucy 7. Nov 2022 11:45

AW: Problem mit myQuery
 
Zitat:

Wobei das ja eigentlich der Compiler dir auch gesagt haben müsste, vonwegen "nicht-initialisierte Variable".



Und natürlich das fehlende count.Refresh; im Timer, falls es nicht woanders schon gemacht wird.
Wobei, würde es woanders gemacht, wozu dann der Timer und nicht direkt dort auf die Änderung prüfen?
ja richtig, vielen Dank für Eure Hilfe :-)

DeddyH 7. Nov 2022 12:07

AW: Problem mit myQuery
 
i ist als lokale Variable immer noch nicht initialisiert, das kann nicht funktionieren. Wurde aber auch schon mehrfach gesagt. Speicher Dir die zuletzt gelesene Anzahl in einem privaten Feld oder zur Not in einer globalen Variablen.

lucy 7. Nov 2022 12:23

AW: Problem mit myQuery
 
Zitat:

i ist als lokale Variable immer noch nicht initialisiert, das kann nicht funktionieren. Wurde aber auch schon mehrfach gesagt. Speicher Dir die zuletzt gelesene Anzahl in einem privaten Feld oder zur Not in einer globalen Variablen.
habe eine globale Variable angelegt. danke

Delphi-Quellcode:
var
  Form1: TForm1;
  zahl: integer = 0;
Delphi-Quellcode:
procedure TForm1.pruefenTimer(Sender: TObject);
 var anzahl: integer;
             s: String;
begin
  count.Refresh;
   anzahl:= count.Fields[0].AsInteger;
  if anzahl <> zahl then
   begin
    zahl := anzahl;
     Label2.Caption := 'Anzahl Datensätze : '+ InttoStr(zahl);
  end
end;

himitsu 7. Nov 2022 13:30

AW: Problem mit myQuery
 
Um dir gleich die Verwendung globaler Variablen abzugewöhnen, bevor du dir solch schlimmen Dinge noch angeöhnst.

DAS ist ja eine Variable, welche innerhalb von Form1 und dessen Methoden verwendet wird, also sollte sie besser auch dort rein.

Delphi-Quellcode:
type
  TForm1 = class(TForm)
    ...
  private
    zahl: integer;
  end;
Und globale Variablen und Felder in Ojekten/Klassen sind per Default mit 0 initialisiert.


Alle Zeitangaben in WEZ +1. Es ist jetzt 04:33 Uhr.
Seite 2 von 2     12   

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