Delphi-PRAXiS

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Datenbanken (https://www.delphipraxis.net/15-datenbanken/)
-   -   Delphi TADOQuery - Zugriff auf große Ergebnismenge sehr langsam (https://www.delphipraxis.net/84916-tadoquery-zugriff-auf-grosse-ergebnismenge-sehr-langsam.html)

Tommahawk 23. Jan 2007 15:50

Datenbank: Microsoft SQL Server • Version: 2005 • Zugriff über: TADOConnection, TADOQuery

TADOQuery - Zugriff auf große Ergebnismenge sehr langsam
 
Hallo liebe Freunde!

Ich melde mich zurück, mit einem neuen Problem. :nerd:

Ich greife mit Hilfe der Komponenten TADOConnection und TADOQuery auf eine MSSQL-Datenbank zu.
Die Ausführung der Abfrage dauert schlappe zehn Sekunden. Dabei erhalte ich eine Ergebnismenge mit rund 180.000 Datensätzen zurück.

Bitte fangt jetzt nicht an zu fragen, wieso die Ergebnismenge so groß ist. Das ist eben so.

Jetzt durchlaufe ich die Ergebnismenge.

Delphi-Quellcode:
...
while not Q.Eof do begin
  Q.Next;
end;
...
Dabei tritt der folgende Effekt auf. Je öfter die Schleife durchlaufen wird, umso langsamer wird die Schleifenabarbeitung.
Woran liegt das?


Ich bin Euch für jede noch so kleine Anregung dankbar.

Thomas a.k.a. Tommahawk

mkinzler 23. Jan 2007 16:21

Re: TADOQuery - Zugriff auf große Ergebnismenge sehr langsam
 
Werden alle Durchläufe in der gleichen Transaktion durchgeführt?

Bernhard Geyer 23. Jan 2007 17:13

Re: TADOQuery - Zugriff auf große Ergebnismenge sehr langsam
 
Folgende Infos fehlen noch:

- Curser-Location
- Vorhandener/Verwendeter Speicher auf Client
- Vorhandener/Verwendeter Speicher auf Server
- Query um abschätzen zu können was der Server alles leisten muß


Alle Zeitangaben in WEZ +1. Es ist jetzt 00:54 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