Schnellere Datenbankschleifen in Delphi

Möglicherweise arbeiten Sie bei Ihrer Datenbankbearbeitung häufig mit vergleichbaren Schleifen:

while not query1.eof do begin
label1.caption:=query1.fieldbyname(‘Feld1’).asString;
label2.caption:=query1.fieldbyname(‘Feld2’).asString;
label3.caption:=query1.fieldbyname(‘Feld3’).asString;
label4.caption:=query1.fieldbyname(‘Feld4’).asString;
// eventuell diverser anderer Code
query1.next;
end;

Fieldbyname verwenden Sie dazu, um Werte aus der Datenbank (bzw. aus der Abfragemenge) auszulesen oder eventuell auch in die Datenbank zu schreiben.

Um diese Schleifen zu optimieren, können Sie einige Tipps verfolgen.

Zum einem sollte natürlich generell so wenig Anweisungen wie möglich in Schleifen abgearbeitet werden, zum anderen ist es wichtig zu sehen, was Fieldbyname eigentlich macht. Fieldbyname holt sich die Feldinformationen für das jeweils angegebene Feld und gibt die entsprechende TField Komponente zurück, die dieses Feld repräsentiert. Dazu sucht Fieldbyname nach dem entsprechenden Feld (letztlich ein Aufruf von FindField), was in einer Schleife dazu führt, dass immer und immer wieder diese Suche ausgeführt wird, was natürlich Zeit kostet. Wie viel Zeit ist dabei natürlich abhängig von der Anzahl der Schleifen, die abgearbeitet werden müssen. Ist zu erwarten, dass nur wenige Schleifen durchlaufen werden müssen, kann man es so belassen.

Der Vorteil der obigen Vorgehensweise liegt auf der Hand: Es ist einfach, es ist klar und der Zeitaufwand für den, der diesen Code schreiben muss, ist überschaubar. Klarer Nachteil ist der Performanceverlust, da jedes Mal nach dem gleichen Feld gesucht werden muss, was letztlich nicht sehr intelligent ist, auf jeden Fall nicht sehr effektiv.

Bei sehr vielen Daten sollte man überlegen, wie man vorgeht, um die Sache zu beschleunigen.

Ein Weg könnte so aussehen:

Var
Feld1, Feld2, Feld3 : TField;
begin
Feld1 := query1.fieldbyname(‘feld1’);
Feld2 := query1.fieldbyname(‘feld2’);
Feld3 := query1.fieldbyname(‘feld3’);
while not query1.eof do
begin
label1.caption:=Feld1.asString;
label2.caption:=Feld2.asString;
label3.caption:=Feld3.asString;
query1.next;
end;
end;

Ein Nachteil dieses Verfahrens ist natürlich ganz klar: Man muss mehr Code schreiben, Vorteil ist aber, dass nicht mehr in jeder Schleifenausführung wieder und wieder nach dem entsprechenden Feld gesucht werden, da eine entsprechende Referenz durch die lokale Variable bereits gesetzt ist. Dies beschleunigt bei sehr vielen Schleifenabläufen durchaus messbar.

Nun müssen Sie natürlich nicht den ganzen Code in Ihren Programmen umschreiben, aber bei zeitkritischen Abfragen lohnt sich eine Überarbeitung bzw. eine Überprüfung, ob man da nicht ein paar Sekunden herausholen kann.

Werbung

Aktuelle Top Aktionen bei Acer, HP, Lenovo, Bitdefender & Co

Angebote bei HP
» Extra Aktion: 10% Gutschein auf HP 17" Notebooks: HP Notebook, HP Pavilion, HP Envy und Omen Modelle zur Auswahl bis 30. Mai (Gutschein: HPTD1XN518)
» HP Extra Aktion: 100 Euro Extra sparen bei HP Notebooks ab 999 Euro. Gutscheincode und alle Infos hier im HP Store

Angebote bei Lenovo
» Lenovo Top Wochenangebote: Heiße ThinkPad und IdeaPad Wochenangebote mit großer Auswahl und dicken Rabatten
» Lenovo Last Chance Gelegenheit: Lenovo Last Chance Angebote mit Notebooks zu Top Preisen hier, u.a. Lenovo IdeaPad 320 und mehr mit bis zu 26% Rabatt. Top Gelegenheit gut ausgestattete Lenovo Notebooks sehr günstig zu bekommen.

Weitere Möglichkeiten
» Top bei Otto: Sehr gute HP Notebook Angebote, teils mit Extras wie 4 Jahre Garantie und mehr
» Notebooksbilliger.de WM Special:Jede Woche 11 neue Top Angebote>
» Mehr Aktionen in der Übersicht: Aktuelle HP Angebote und mehr auf einem Blick

Aktuelle Bitdefender Aktionen:
» Neue Aktion: Bitdefender 39 Euro Flat mit 5 Geräten
» Bitdefender +1 Jahr dazu-Aktion
» „Sicher durch den Sommer“ - Bitdefender Jahres Lizenz mit bis zu 36% Rabatt kaufen, inklusive VPN Basis-Paket.
» Top für neue PCs! Bitdefender Internet Security 2018 PC Lebenslang Edition: 5 Jahre Schutz für nur für nur 89,95

Weitere aktuelle Bitdefender Angebote » Alle Bitdefender Angebote auf einem Blick

Werbung

Verwandte Themen:


Sorry! Unser Kommentarfunktion ist vorübergehend geschlossen.