AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi Query mit Parametern vorbereiten
Thema durchsuchen
Ansicht
Themen-Optionen

Query mit Parametern vorbereiten

Ein Thema von barnti · begonnen am 10. Mär 2004 · letzter Beitrag vom 10. Mär 2004
Antwort Antwort
Seite 2 von 2     12   
barnti

Registriert seit: 15. Aug 2003
Ort: Mal hier mal da...
689 Beiträge
 
Delphi 7 Enterprise
 
#11

Re: Query mit Parametern vorbereiten

  Alt 10. Mär 2004, 10:32
@ sharky:

ich verwende im Moment im Quelltext 'normale' Stringvariablen, die ich mit 'QuotedStr(Variable)' in das Statement einbinde. Habe gedacht Paramerter wären die bessere Lösung...
Gruß,

Barnti
  Mit Zitat antworten Zitat
Benutzerbild von Sharky
Sharky

Registriert seit: 29. Mai 2002
Ort: Frankfurt
8.252 Beiträge
 
Delphi 2006 Professional
 
#12

Re: Query mit Parametern vorbereiten

  Alt 10. Mär 2004, 10:37
Hai barnti,

ich hatte die Situation noch nicht das ich erst zur Laufzeit festlegen musste welche Tabelle oder welches Feld überprüft wird

Aber hier eine "Lösung" für Dein Problem:

Delphi-Quellcode:
procedure TForm1.Button1Click(Sender: TObject);
begin
 with ZQuery1 do
 begin
   Close;
   SQL.Clear;
   SQL.Add('SELECT *');
   SQL.Add('FROM test1');
   SQL.Add('WHERE :key = :Value1');
   SQL.Text := StringReplace(SQL.Text,':key',Edit1.Text,[rfReplaceAll,rfIgnoreCase]);
   ParamByName('Value1').AsString:= Edit2.Text;
   Open;
 end;
end;
Stephan B.
"Lasst den Gänsen ihre Füßchen"
  Mit Zitat antworten Zitat
barnti

Registriert seit: 15. Aug 2003
Ort: Mal hier mal da...
689 Beiträge
 
Delphi 7 Enterprise
 
#13

Re: Query mit Parametern vorbereiten

  Alt 10. Mär 2004, 10:41
Hallo Sharky,

das ist fein

werde ich gleich mal ausprobieren. Danke Dir vielmals!
Gruß,

Barnti
  Mit Zitat antworten Zitat
Benutzerbild von r_kerber
r_kerber

Registriert seit: 11. Feb 2003
Ort: Trittau
3.538 Beiträge
 
Delphi XE Professional
 
#14

Re: Query mit Parametern vorbereiten

  Alt 10. Mär 2004, 10:58
Zitat von Sharky:
Delphi-Quellcode:
procedure TForm1.Button1Click(Sender: TObject);
begin
 with ZQuery1 do
 begin
   Close;
   SQL.Clear;
   SQL.Add('SELECT *');
   SQL.Add('FROM test1');
   SQL.Add('WHERE :key = :Value1');
   SQL.Text := StringReplace(SQL.Text,':key',Edit1.Text,[rfReplaceAll,rfIgnoreCase]);
   ParamByName('Value1').AsString:= Edit2.Text;
   Open;
 end;
end;
Warum nicht so:
   SQL.Add('WHERE ' + Trim (Edit1.Text) + ' = :Value1');
  Mit Zitat antworten Zitat
Benutzerbild von Sharky
Sharky

Registriert seit: 29. Mai 2002
Ort: Frankfurt
8.252 Beiträge
 
Delphi 2006 Professional
 
#15

Re: Query mit Parametern vorbereiten

  Alt 10. Mär 2004, 11:36
Hai r_kerber,


Zitat von barnti:
...Das wäre sehr schade, denn die Benutzung von Parametern fördert die Lesbarkeit ungemein....
barnti wollte es ja so haben
Stephan B.
"Lasst den Gänsen ihre Füßchen"
  Mit Zitat antworten Zitat
Benutzerbild von r_kerber
r_kerber

Registriert seit: 11. Feb 2003
Ort: Trittau
3.538 Beiträge
 
Delphi XE Professional
 
#16

Re: Query mit Parametern vorbereiten

  Alt 10. Mär 2004, 11:57
Aber im SQL gibt es nun mal keine Parameter für Feldnamen. Warum soll er sich so etwas Falsches dann erst angewöhnen? Wenn er dass dan mit "normalem" SQL-Zugriff versucht, hat er wieder Probleme! Und ob die Geschichte mit dem StringReplace die Lesbarkeit tatsächlich verbessert, wage ich zu bezweifeln.
  Mit Zitat antworten Zitat
Robert_G
(Gast)

n/a Beiträge
 
#17

Re: Query mit Parametern vorbereiten

  Alt 10. Mär 2004, 12:58
Eine bessere Lesbarkeit lässt sich auch so erreichen:
Delphi-Quellcode:
   ...
   SQL.Text := Format(
     'SELECT *' + #10 +
     'FROM test1' + #10 +
     'WHERE %s = :Value1'
     ,[Edit1.Text]);
   ...
Das ist aber, wie r_Kerber shon gesagt hat, nicht wirklich das Gelbe vom Ei.

Eine andere Möglichkeit wären Substitution (Ersetzungs) -Variablen, wenn deine DB-Kompos das unterstützen.
Das sieht mit DOA so aus:
Delphi-Quellcode:
With OracleQuery Do
Begin
  SQL.Text :=
    'SELECT *' + #10 +
    'FROM test1' + #10 +
    'WHERE :Key = :Value1';
  DeclareVariable('Key', otSubst);
  DeclareVariable('Value1', otString);
  SetVariable('Key', Edit1.Text);
  SetVariable('Value1', Edit2.Text);
  Execute;
  ...
End;
Weil sich bei beiden Lösungen das Statement ändert muss der Server den Code neu parsen und ausführen.
Überlege dir also genau, wann du diese Ersetzungen einsetzt...
  Mit Zitat antworten Zitat
barnti

Registriert seit: 15. Aug 2003
Ort: Mal hier mal da...
689 Beiträge
 
Delphi 7 Enterprise
 
#18

Re: Query mit Parametern vorbereiten

  Alt 10. Mär 2004, 13:04
Hallo Leute,

in erster Linie geht es mir um die Lesbarkeit, das ist richtig. Weiter hat es für mich den Vorteil, dass ich auf 'QuotedStr' verzichten kann.

Ist halt Geschmackssache...
Gruß,

Barnti
  Mit Zitat antworten Zitat
Benutzerbild von r_kerber
r_kerber

Registriert seit: 11. Feb 2003
Ort: Trittau
3.538 Beiträge
 
Delphi XE Professional
 
#19

Re: Query mit Parametern vorbereiten

  Alt 10. Mär 2004, 13:30
Hallo Robert,

ich würde Deinen ersten Vorschlg favorisieren, da hier nicht it "falschem Parameter" gearbeitet wir.

@Barnti: Dein Wunsch in Ehren. Du solltest aber versuchen, mit korrekten SQL-Statements zu arbeiten. Und in SQL gibt es nun mal keine Parameter für Tabellenfelder! Nicht nur der Delphi-Quellcode sollte korrekt sein sondern auch der "SQL-Quellcode"! Und wie Robert schon schrieb, denke auch an die Ausführungs-Performance der SQL-Statements.
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 2 von 2     12   


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 10:06 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