![]() |
SQL - Parameter
Hi,
folgendes Problem : Die in einem Editfeld stehende Kunden-Nr. soll über einen Parameter an eine SQL - Abfrage geliefert werden. Diese soll dann den Kunden irgendwo anzeigen.
Code:
Lasse ich das so ablaufen, heißt es "Parameter KDNR does not exist on Form". Zumindest, daß etwas mit einem Parameter gemacht werden soll, hat Delphi also erkannt. :mrgreen: Wer weiß, was da fehlt oder falsch ist :?:
procedure TForm1.Edit1Exit(Sender: TObject);
begin KuDS.Active := false; KuDS.ParamByName ('KDNR').AsInteger := StrToInt (Edit1.Text); KuDS.SelectSQL.Text := 'SELECT * FROM KUNDE WHERE NR = :KDNR'; KuDS.Active := true; end; |
Re: SQL - Parameter
Zitat:
hast Du denn den Parameter auch im OI angegeben (unter Params)? Oder ihn im Code erzeugt? |
Re: SQL - Parameter
Bei meinem DataSet gibts kein Params, zumindest nicht im OI.
|
Re: SQL - Parameter
Zitat:
Hmmm.... ich verwende die ADOs.... dort habe ich die bei den Querys und bei den DataSets. |
Hi Hansa,
wenn ich den Namen für den Pasameter nicht setzen möchte (Faulheit), schreibe ich folgendes:
Delphi-Quellcode:
und die Abfrage wie Du sie geschrieben hast.
MyQuery.Params[0].Value := KdNr;
Will ich keine Params verwenden, oder es gibt keine wie bei Dir, dann verwende ich die Variable in der Abfrage zur Laufzeit. Bsp.:
Delphi-Quellcode:
Gruß oki
KdNr := StrtoInt(Edit1.Text);
KuDS.SelectSQL.Text := 'SELECT * FROM KUNDE WHERE NR = '''+ KDNR +'''; |
Re: SQL - Parameter
Hi,
Zitat:
KuDS.Prepare ein Grüße Lemmy |
Zitat:
SQL-Code:
So gehts auch nicht. Dann kommt : "Cannot assign to Read-Only property"KuDataSet.Params[0].Name := 'KDNR'; KuDataSet.SelectSQL.Text := 'SELECT * FROM KUNDE WHERE NR = :KDNR'; Also : ich brauche einen Parameter, den ich im SelectSQL nutzen kann. Dem muß ich doch wohl einen Namen geben, oder nicht ? Zur Laufzeit soll der Parameter dann einen gültigen Wert erhalten und im Select benutzt werden können. |
Hallo Hansa,
ich vermute, es liegt an der Reihenfolge. Vor der Anweisung:
Delphi-Quellcode:
gibt es noch gar keine Parameter. Die Zuweisung an die SQL Eigenschaft, bei der ein Parameter benutzt wird erzeugt aber einen Parameter, den du nutzen kannst. Also erst die Zuweisung des SQL Strings, dann Zugriff auf den Params Array. Es sei denn, du legst den Parameter bereits vorher, z.B. über die IDE an.
KuDataSet.SelectSQL.Text := 'SELECT * FROM KUNDE WHERE NR = :KDNR';
|
Re: SQL - Parameter
Zitat:
@MrSpock,Lemmy: Danke für die Hilfe. Da hatte ich echt einen Knoten im Gehirn. |
Jetzt hänge ich wieder fest. Das ganze ging, aber jetzt nicht mehr bis zum Schluß.
Code:
was ist denn jetzt hier falsch ?
Active := false;
SelectSQL.Text :='SELECT * FROM KUSTAT WHERE JAHR = ' + LabeledEdit1.text + ' AND MONAT = ' + IntToStr (i) + ' AND ID_KUNR = :KDNR'; StatModul.StatDS.ParamByName ('KDNR').AsInteger := KuModul.KuDataSet.FieldByName ('ID').AsInteger; Series1.AddXY(i,(FieldByName ('UMSATZ').value )); wieso beschwert sich Delphi : "Field ID not found" :?: Bei den SQLs stehts richtig drin. So ein Mist ! |
Alle Zeitangaben in WEZ +1. Es ist jetzt 01:59 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