Delphi-PRAXiS
Seite 1 von 2  1 2      

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 28. Okt 2022 10:14

Datenbank: mariadb • Version: ??? • Zugriff über: mydac

Problem mit myQuery
 
hallo, versuche mit myQuery1 u. myQuery2 zu prüfen, ob die Anzahl der Datensätze ungleich sind.

Code:
Code: myQuery 1 und 2

SELECT ts_number.id FROM ts_number WHERE ts_number.id = 2
hier mein Timer:

Code:
procedure TForm1.RefreshTimer(Sender: TObject);
var zahl1, zahl2 : Integer;
begin
 MyQuery1.Refresh;
  zahl1 := MyQuery1.RecordCount;
  if zahl1 <> zahl2 then
   begin
      MyQuery2.Refresh;
      zahl2 := MyQuery2.RecordCount;
      Memo1.Lines.Add ('Status: ' + datetostr(date) + ' | ' + timetostr(time) + Format(' : Refresh Query RecordCount: %d',[MyQuery2.RecordCount]));
   end;
end;
das Ergebnis im Memo1 sieht so aus:

Server 1.0
Status: 28.10.2022 | 11:00:29 : Server MySQL gestartet
Status: 28.10.2022 | 11:00:29 : Anzahl Datensätze: 555
Status: 28.10.2022 | 11:00:35 : Refresh Query RecordCount: 555
Status: 28.10.2022 | 11:01:23 : Refresh Query RecordCount: 555
Status: 28.10.2022 | 11:01:29 : Refresh Query RecordCount: 555
Status: 28.10.2022 | 11:01:35 : Refresh Query RecordCount: 555
Status: 28.10.2022 | 11:01:41 : Refresh Query RecordCount: 556
Status: 28.10.2022 | 11:01:53 : Refresh Query RecordCount: 556
Status: 28.10.2022 | 11:02:11 : Refresh Query RecordCount: 556
Status: 28.10.2022 | 11:02:14 : Server MySQL gestoppt


Warum wird die Anzahl der Datensätze nicht sofort geändert ? Timer steht auf 6 Sekunden

himitsu 28. Okt 2022 11:28

AW: Problem mit myQuery
 
Warum hörst du nicht auf das, was dir dein Compiler bestimmt zu sagen versucht?

Zitat:

Delphi-Quellcode:
if zahl1 <> zahl2 then

Zahl2 ist hier noch garnicht initialisiert, weil DU dieser Variable noch nichts zugewiesen hast, denn das machst du erst danach,
und da lokale Variablen nicht (alle) automatisch initialisiert werden, steht darin ein Zufallswert.


Außerdem, du willst nur sie Anzahl wissen, aber lädst gleich alles runter? Ein bisschen unnötig viel Traffic und Speicher. :angle:
SQL-Code:
SELECT count(ts_number.id) FROM ts_number WHERE ts_number.id = 2

Delphi-Quellcode:
MyQuery2.FieldByName('count').AsInteger
bzw.
Delphi-Quellcode:
MyQuery2.Fields[0].AsInteger

lucy 7. Nov 2022 08:16

AW: Problem mit myQuery
 
Liste der Anhänge anzeigen (Anzahl: 1)
guten morgen,

habe eine query(count), wie frage ich jetzt die Anzahl der Datensätze ab?

Delphi-Quellcode:
procedure TForm1.pruefenTimer(Sender: TObject);
 var anzahl: integer;
begin
  anzahl:= count.FieldByName('id').AsInteger; // das ist falsch
  Label2.Caption := 'Anzahl Datensätze : '+ InttoStr(anzahl);
end;

lucy 7. Nov 2022 08:18

AW: Problem mit myQuery
 
ach ja,

habe nicht alles gelesen :-)

hiermit geht es :

Delphi-Quellcode:
MyQuery2.Fields[0].AsInteger;

lucy 7. Nov 2022 08:36

AW: Problem mit myQuery
 
wird trotzdem nur einmal ausgelesen (timer) ?


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

DeddyH 7. Nov 2022 09:02

AW: Problem mit myQuery
 
Wo führst Du denn Deine Query aus? Im Timer ja augenscheinlich nicht, wie soll man da also Änderungen mitbekommen?

lucy 7. Nov 2022 09:37

AW: Problem mit myQuery
 
Liste der Anhänge anzeigen (Anzahl: 1)
Zitat:

Wo führst Du denn Deine Query aus? Im Timer ja augenscheinlich nicht, wie soll man da also Änderungen mitbekommen?
Delphi-Quellcode:
if anzahl <> count.Fields[0].AsInteger then
count ist meine Query

DeddyH 7. Nov 2022 09:42

AW: Problem mit myQuery
 
Schön. Die wird einmal ausgeführt und enthält dann die Anzahl der Datensätze zum Zeitpunkt der Ausführung. Solange Du sie nicht erneut ausführst, wird sich diese Anzahl aber niemals ändern.

lucy 7. Nov 2022 09:49

AW: Problem mit myQuery
 
Zitat:

Schön. Die wird einmal ausgeführt und enthält dann die Anzahl der Datensätze zum Zeitpunkt der Ausführung. Solange Du sie nicht erneut ausführst, wird sich diese Anzahl aber niemals ändern.
ok, deshalb setze ich ja einen Timer ein. aber das wird dann der falsche Weg sein! habe hier noch einen Denkfehler :-) drin

Jasocul 7. Nov 2022 09:59

AW: Problem mit myQuery
 
"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.


Alle Zeitangaben in WEZ +1. Es ist jetzt 17:52 Uhr.
Seite 1 von 2  1 2      

Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz