Delphi-PRAXiS

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Datenbanken (https://www.delphipraxis.net/15-datenbanken/)
-   -   Delphi Übergabeparameter in SQL-String Where-Clause einfügen (https://www.delphipraxis.net/28320-uebergabeparameter-sql-string-where-clause-einfuegen.html)

Tonik 23. Aug 2004 09:54


Übergabeparameter in SQL-String Where-Clause einfügen
 
Hallo zusammen,

Ich habe folgendes Problem:
Delphi-Quellcode:
procedure TBestandsanalyseView.GenerateQuery(KundenID:String);
var
  SQLKrit : String;
begin
  SQLKrit:='Select Status,Praemie,Zahlung,Courtproz From Vertrag v Where v."KEY"='KundenID';
  AddQuery(SQLKrit);
end;
Das geht natürlich nicht:
Where v."KEY"='KundenID', aber wie bekomm ich es hin, dass mein Übergabeparameter im SQL-String in Anführunszeichen steht ohne diesen dadurch zu schliessen ?

Grüße
Micha

[edit=Sharky]Delphi-Tags gesetzt. Mfg, Sharky[/edit]

Bernhard Geyer 23. Aug 2004 09:56

Re: Übergabeparameter in SQL-String Where-Clause einfügen
 
1, Du solltest wenn möglich parametrisierte Abfragen verwenden

2, Einfach quoten:
SQL-Code:
'Select Status,Praemie,Zahlung,Courtproz From Vertrag v Where v."KEY"=''KundenID''';

Tonik 23. Aug 2004 10:08

Re: Übergabeparameter in SQL-String Where-Clause einfügen
 
Hallo Bernhard,

und Danke für die schnelle Antwort.
Wenn ich es so mache wie Du geschrieben hast, steht in meinem SQL-String dann

...Where v."KEY"='KundenID'

Er fügt jedoch nicht den Inhalt von KundenID an der Stelle ein sondern den String "KundenID"
ich suche nach einem Weg den Inhalt einzufügen und trotzdem die einzelnen Anführungszeichen davor und dahinter zu platzieren ohne die die Abfrage ja nicht funktioniert.

Sharky 23. Aug 2004 10:12

Re: Übergabeparameter in SQL-String Where-Clause einfügen
 
Hai Tonik,

mit welchen Komponenten arbeitest Du denn für den zugriff auf deine Datenbank?

P.S.: Herzlich Willkommen in der Delphi-PRAXIS.

Tonik 23. Aug 2004 10:19

Re: Übergabeparameter in SQL-String Where-Clause einfügen
 
Hi Sharky,

so sieht die Sache bei mir aus:
Ich benutze NextQuery vom Typ TSQLQuery in AddQuery. Das ist aber alles geerbt, ich muss nur 'nen sauberen SQL-String generieren in dem der Inhalt von Kunden ID in einzelnen Anführungsstrichen steht und den übergeben.
Delphi-Quellcode:
procedure TBestandsanalyseView.GenerateQuery(KundenID:String);
var
  SQLKrit : String;
begin
  SQLKrit:='Select Status,Praemie,Zahlung,Courtproz From Vertrag v Where v."KEY"=''KundenID''';
  AddQuery(SQLKrit);
end;

procedure TBestandsanalyseView.AddQuery(SQL:String);
var
  NextQuery : TAfnQuery;
  zahlfaktor : integer;
  jahresNettoPraemie,praemie,vermittlerAnteil : double;
begin
  NextQuery:=TAfnQuery.Create(self);
  NextQuery.SQLConnection := BuSession.DbSession.DBServer;
  NextQuery.Execute(SQL);
  while not NextQuery.Eof do
  begin
  ...
end;
[edit=Sharky]Delphi-Tags gesetzt. Bitte beim nächsten mal selber machen ;-) Mfg, Sharky[/edit]

lume96 23. Aug 2004 10:20

Re: Übergabeparameter in SQL-String Where-Clause einfügen
 
Hallo,

sollte KEY in der Datenbank ein INTEGER, etc... sein, dann so
Delphi-Quellcode:
SQLKrit := 'Select Status,Praemie,Zahlung,Courtproz From Vertrag v Where v.KEY='+KundenID;
wenn KEY ein varchar, etc... ist, dann so :

Delphi-Quellcode:
SQLKrit := 'Select Status,Praemie,Zahlung,Courtproz From Vertrag v Where v.KEY='''+KundenID+'''';
MfG
Lutz

Sharky 23. Aug 2004 10:23

Re: Übergabeparameter in SQL-String Where-Clause einfügen
 
Hai Tonik,

ich kenne diese Query-Komponente nicht und weis nicht ob diese mit Parametern arbeiten kann.
Normalerweise würde ich das so machen:
Delphi-Quellcode:
procedure TForm1.Button1Click(Sender: TObject);
var
  kunden_id : String;
begin
  kunden_id := '0815';
  ADOQuery1.Close;
  ADOQuery1.SQL.Text :=
  'Select Status,Praemie,Zahlung,Courtproz From Vertrag v' +#10
  +' Where v."KEY"= :kunden_id';
  ADOQuery1.ParamCheck := True; // Parametercheck aktivieren
  ADOQuery1.Parameters.ParamByName('kunden_id').AsString := KundenID; //Parameter setzen.
  ADOQuery1.Open;
end;
Sollte es so nicht gehen verwende doch einfach die Funktion QuotedStr.
Delphi-Quellcode:
begin
  SQLKrit := 'Select Status,Praemie,Zahlung,Courtproz From Vertrag v Where v.KEY=' + QuotedStr (KundenID);

Tonik 23. Aug 2004 10:26

Re: Übergabeparameter in SQL-String Where-Clause einfügen
 
Hallo Lutz !

klappt wunderbar wie Du geschrieben hast, vielen Dank (und den anderen natürlich auch) !!!

Grüße
Micha


Alle Zeitangaben in WEZ +1. Es ist jetzt 19:27 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