AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi Übergabeparameter in SQL-String Where-Clause einfügen
Thema durchsuchen
Ansicht
Themen-Optionen

Übergabeparameter in SQL-String Where-Clause einfügen

Ein Thema von Tonik · begonnen am 23. Aug 2004 · letzter Beitrag vom 23. Aug 2004
Antwort Antwort
Tonik

Registriert seit: 23. Aug 2004
4 Beiträge
 
#1

Übergabeparameter in SQL-String Where-Clause einfügen

  Alt 23. Aug 2004, 09:54
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]
  Mit Zitat antworten Zitat
Benutzerbild von Bernhard Geyer
Bernhard Geyer

Registriert seit: 13. Aug 2002
17.171 Beiträge
 
Delphi 10.4 Sydney
 
#2

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

  Alt 23. Aug 2004, 09:56
1, Du solltest wenn möglich parametrisierte Abfragen verwenden

2, Einfach quoten:
'Select Status,Praemie,Zahlung,Courtproz From Vertrag v Where v."KEY"=''KundenID''';
Windows Vista - Eine neue Erfahrung in Fehlern.
  Mit Zitat antworten Zitat
Tonik

Registriert seit: 23. Aug 2004
4 Beiträge
 
#3

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

  Alt 23. Aug 2004, 10:08
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.
  Mit Zitat antworten Zitat
Benutzerbild von Sharky
Sharky

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

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

  Alt 23. Aug 2004, 10:12
Hai Tonik,

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

P.S.: Herzlich Willkommen in der Delphi-PRAXIS.
Stephan B.
"Lasst den Gänsen ihre Füßchen"
  Mit Zitat antworten Zitat
Tonik

Registriert seit: 23. Aug 2004
4 Beiträge
 
#5

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

  Alt 23. Aug 2004, 10:19
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]
  Mit Zitat antworten Zitat
Benutzerbild von lume96
lume96

Registriert seit: 14. Sep 2003
Ort: Rognac/Marseille - Frankreich
128 Beiträge
 
Delphi 7 Professional
 
#6

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

  Alt 23. Aug 2004, 10:20
Hallo,

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

SQLKrit := 'Select Status,Praemie,Zahlung,Courtproz From Vertrag v Where v.KEY='''+KundenID+''''; MfG
Lutz
Lutz Meyer
  Mit Zitat antworten Zitat
Benutzerbild von Sharky
Sharky

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

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

  Alt 23. Aug 2004, 10:23
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);
Stephan B.
"Lasst den Gänsen ihre Füßchen"
  Mit Zitat antworten Zitat
Tonik

Registriert seit: 23. Aug 2004
4 Beiträge
 
#8

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

  Alt 23. Aug 2004, 10:26
Hallo Lutz !

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

Grüße
Micha
  Mit Zitat antworten Zitat
Antwort Antwort


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 00:47 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