AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi TADODataset durchscrollen wird immer langsamer

TADODataset durchscrollen wird immer langsamer

Ein Thema von alzaimar · begonnen am 12. Okt 2006 · letzter Beitrag vom 12. Okt 2006
 
alzaimar
(Moderator)

Registriert seit: 6. Mai 2005
Ort: Berlin
4.956 Beiträge
 
Delphi 2007 Enterprise
 
#1

TADODataset durchscrollen wird immer langsamer

  Alt 12. Okt 2006, 11:11
Datenbank: Egal (ist aber MSSQL) • Zugriff über: ADO
Ich habe hier eine Tabelle mit 50.000 Datensätzen. Die wollte ich mal einlesen und durchscrollen (mit MyDataset.Next)...

Das wird ja immer langsamer, je weiter hinten man sich in der Tabelle befindet!

Für die ersten 1000 Zeilen werden in 16 ms durchgescrollt, die Zeilen 40000-41000 dagegen in 1218ms! Die Zunahme ist übrigens linear, pro 1000 Zeilen wird das Ganze um ca. 30ms langsamer.

Kann das jemand nachvollziehen? (Vermutlich) und kennt jemand einen Trick, wie man das umgehen kann?

Hier der Code (vielleicht werde ich ja einfach alt):
Delphi-Quellcode:
Procedure TForm1.Button1Click(Sender: TObject);
Var
  t: Cardinal;
  n : Integer;

Begin
  ADODataset1.Open;
  t := GetTickCount;
  n := 0;
  While Not ADODataset1.eof Do Begin
    inc(n);
    If n Mod 1000 = 0 Then Begin
      memo1.lines.add(format('%d %d', [n, GetTickCount - t]));
      t := GetTickCount;
    End;
    ADODataset1.Next;
  End;
End;
Da das Memo nur 44 mal angefasst wird, hab ich mir ein BeginUpdate/EndUpdate übrigens gespart. Bringt hier sowieso nix.
"Wenn ist das Nunstruck git und Slotermeyer? Ja! Beiherhund das Oder die Flipperwaldt gersput!"
(Monty Python "Joke Warefare")
  Mit Zitat antworten Zitat
 

Themen-Optionen Thema durchsuchen
Thema durchsuchen:

Erweiterte Suche
Ansicht

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 15:46 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