![]() |
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:
Dabei tritt der folgende Effekt auf. Je öfter die Schleife durchlaufen wird, umso langsamer wird die Schleifenabarbeitung.
...
while not Q.Eof do begin Q.Next; end; ... Woran liegt das? Ich bin Euch für jede noch so kleine Anregung dankbar. Thomas a.k.a. Tommahawk |
Re: TADOQuery - Zugriff auf große Ergebnismenge sehr langsam
Werden alle Durchläufe in der gleichen Transaktion durchgeführt?
|
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 20:27 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