![]() |
Übergabeparameter in SQL-String Where-Clause einfügen
Hallo zusammen,
Ich habe folgendes Problem:
Delphi-Quellcode:
Das geht natürlich nicht:
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; 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] |
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''';
|
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. |
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. |
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:
[edit=Sharky]Delphi-Tags gesetzt. Bitte beim nächsten mal selber machen ;-) Mfg, Sharky[/edit]
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; |
Re: Übergabeparameter in SQL-String Where-Clause einfügen
Hallo,
sollte KEY in der Datenbank ein INTEGER, etc... sein, dann so
Delphi-Quellcode:
wenn KEY ein varchar, etc... ist, dann so :
SQLKrit := 'Select Status,Praemie,Zahlung,Courtproz From Vertrag v Where v.KEY='+KundenID;
Delphi-Quellcode:
MfG
SQLKrit := 'Select Status,Praemie,Zahlung,Courtproz From Vertrag v Where v.KEY='''+KundenID+'''';
Lutz |
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:
Sollte es so nicht gehen verwende doch einfach die Funktion QuotedStr.
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;
Delphi-Quellcode:
begin
SQLKrit := 'Select Status,Praemie,Zahlung,Courtproz From Vertrag v Where v.KEY=' + QuotedStr (KundenID); |
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 22:37 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 by Thomas Breitkreuz