AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi ZEOS-Query gibt falschen Recordcount zurück
Thema durchsuchen
Ansicht
Themen-Optionen

ZEOS-Query gibt falschen Recordcount zurück

Ein Thema von TheJeed · begonnen am 19. Jan 2010 · letzter Beitrag vom 19. Jan 2010
Antwort Antwort
Benutzerbild von TheJeed
TheJeed

Registriert seit: 11. Jun 2009
Ort: Leipzig
57 Beiträge
 
#1

ZEOS-Query gibt falschen Recordcount zurück

  Alt 19. Jan 2010, 11:44
Datenbank: PostgreSQL • Version: 8.3 • Zugriff über: ZEOS
Hallo zusammen!

Bisher hatte ich kaum mal echte Probleme bei der Verwendung der ZEOS-Komponenten. Doch nun stehe ich vor einem kleinen Rätsel. Ich möchte aus einer ganz einfachen Tabelle sämtliche Datensätze holen. Das mache ich so:
Delphi-Quellcode:
    lcon:=TZConnection.Create(nil);
    lcon.Protocol:='...';
    lcon.HostName:='...';
    lcon.Port:=5432;
    lcon.User:='...';
    lcon.Database:='...';
    lcon.Password:='...';
    lcon.Properties.Values['codepage']:='UTF8';
    lcon.Properties.Values['client_encoding']:='UTF8';
    lcon.Connect;

    lroq:=TZQuery.Create(nil);
    lroq.Options:=[doOemTranslate,doCalcDefaults];
    lroq.Connection:=con;

    lroq.SQL.Clear;
    lroq.SQL.Add('SELECT * FROM basket;');
    lroq.ExecSQL;

    lroq.Open;

Direkt danach frage ich ab, wieviele Ergebnis-Datensätze ich bekommen habe:
 c:=lroq.RecordCount; Ich habe ganz exakt eine Zeile in der Datenbank, allerdings ist c gleich 2. Wenn ich die Ergebnisse in der nun folgenden Schleife abfrage, dann bekomme ich auch zwei Mal den Inhalt der einen, tatsächlich existierenden Zeile aus der DB. Und ja, ich rufe lroq.Next auf.

Kann mich jemand mit der Nase in meinen Fehler reindrücken, den ich noch nicht sehe? Oder ist das vielleicht ein bekanntes Problem der ZEOS Library?

Besten Dank
Teitmaschine Go!
  Mit Zitat antworten Zitat
Benutzerbild von DeddyH
DeddyH

Registriert seit: 17. Sep 2006
Ort: Barchfeld
27.542 Beiträge
 
Delphi 11 Alexandria
 
#2

Re: ZEOS-Query gibt falschen Recordcount zurück

  Alt 19. Jan 2010, 12:00
Und wenn Du die Zeile mit ExecSQL mal weglässt?
Detlef
"Ich habe Angst vor dem Tag, an dem die Technologie unsere menschlichen Interaktionen übertrumpft. Die Welt wird eine Generation von Idioten bekommen." (Albert Einstein)
Dieser Tag ist längst gekommen
  Mit Zitat antworten Zitat
Benutzerbild von TheJeed
TheJeed

Registriert seit: 11. Jun 2009
Ort: Leipzig
57 Beiträge
 
#3

Re: ZEOS-Query gibt falschen Recordcount zurück

  Alt 19. Jan 2010, 12:12
Danke für Deine Antwort. Leider ändert sich dadurch nichts.
Teitmaschine Go!
  Mit Zitat antworten Zitat
hoika

Registriert seit: 5. Jul 2006
Ort: Magdeburg
8.270 Beiträge
 
Delphi 10.4 Sydney
 
#4

Re: ZEOS-Query gibt falschen Recordcount zurück

  Alt 19. Jan 2010, 12:20
Hallo,

bei einer SQL-Datenbank sollte man RecordCount nicht verwenden.
Es kann sein, dass ZEOS hier was falsch macht.

Dafür gibt es Select Count(*)

Delphi-Quellcode:
Wozu brauchst du das überhaupt ?

with Query do
begin
  Open;
  try
    while not Eof do
    begin

    // Datensatz lesen und verwenden

      Next;
    end;
  finally
    Close;
  end;
end;

Heiko
Heiko
  Mit Zitat antworten Zitat
Benutzerbild von TheJeed
TheJeed

Registriert seit: 11. Jun 2009
Ort: Leipzig
57 Beiträge
 
#5

Re: ZEOS-Query gibt falschen Recordcount zurück

  Alt 19. Jan 2010, 12:29
Ah, interessant. Dann werde ich mich künftig an Deine Methode halten.

Aber mir ist gerade die Lösung meines Problems aufgefallen: Meine Query geht an die falsche Datenbank - und zwar wegen der mir angeborenen Blödheit.
 lroq.Connection:=con; Da ich ein Stück Quelltext kopiert und nicht korrekt angepasst habe, geht meine Query an die falsche Datenbank raus, nämlich an "con", nicht "lcon".

Tut mir Leid, die Pferde scheu gemacht zu haben!

Nix für ungut
Teitmaschine Go!
  Mit Zitat antworten Zitat
hoika

Registriert seit: 5. Jul 2006
Ort: Magdeburg
8.270 Beiträge
 
Delphi 10.4 Sydney
 
#6

Re: ZEOS-Query gibt falschen Recordcount zurück

  Alt 19. Jan 2010, 12:31
Hallo,

argzzzzzz, was für Variablen-Namen

lcon, local con ?


Heiko
Heiko
  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 00:01 Uhr.
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