![]() |
Datenbank: Firebird • Version: 1.5 • Zugriff über: FIBPlus
Effektives Query
Hallo,
ich hab da mal ne prinzipielle Frage. Irgendwo habe ich gelesen, das es effektiver sei, Queries mit Parametern zu nutzen, als das Query direkt aufzubauen. Nur würde ich gerne wissen, was da dran ist... Nehmen wir als Beispiel mal ne Suche in einer Kundendatenbank. Ich denk mal, die Variablennamen/Feldnamen etc. sind eindeutig. Man könnte schreiben (direkt)
Delphi-Quellcode:
oder mittels Parameter
sQuery := 'SELECT * FROM KUNDE WHERE ';
blMore := false; if(edtKundennummer.Text <> '') then begin sQuery := sQuery + 'KUNDEID LIKE ' + edtKundenummer.Text + '%'; blMore := true; end; if(edtName.Text <> '') then begin if(blMore = true) then sQuery := sQuery + 'AND '; sQuery := sQuery + 'NAME LIKE ' + edtName.Text + '%'; blMore := true; end; if(edtOrt.Text <> '') then begin if(blMore = true) then sQuery := sQuery + 'AND '; sQuery := sQuery + 'ORT LIKE ' + edtOrt.Text + '%'; blMore := true; end; qryKunde.SQL.Add(sQuery); qryKunde.ExecSQL;
Delphi-Quellcode:
Der Code ist jetzt nur fix zusammengehackt, nur um zu verdeutlichen, was ich meine.
sQuery := 'SELECT * FROM KUNDE WHERE ';
blMore := false; if(edtKundennummer.Text <> '') then begin sQuery := sQuery + 'KUNDEID LIKE :KUNDE'; blMore := true; end; if(edtName.Text <> '') then begin if(blMore = true) then sQuery := sQuery + 'AND '; sQuery := sQuery + 'NAME LIKE :NAME'; blMore := true; end; if(edtOrt.Text <> '') then begin if(blMore = true) then sQuery := sQuery + 'AND '; sQuery := sQuery + 'ORT LIKE :ORT'; blMore := true; end; qryKunde.SQL.Add(sQuery); //mal davon ausgehen, das die Parameter existieren, ist ja nur ein Beispiel :) qryKunde.ParamByName('KUNDEID').AsString := edtKundenNummer.Text + '%'; //undsoweiter qryKunde.Prepare; qryKunde.ExecSQL; |
Re: Effektives Query
Zitat:
Effektiver ist es nur wenn du die Queries preparest und mehrmals verwendest. Dann muß nur einmal die Query analysiert werden und ein Abfrageplan erstellt werden. |
Alle Zeitangaben in WEZ +1. Es ist jetzt 19:22 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