AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Thema durchsuchen
Ansicht
Themen-Optionen

SQL - Parameter

Ein Thema von Hansa · begonnen am 17. Feb 2003 · letzter Beitrag vom 18. Feb 2003
Antwort Antwort
Seite 1 von 3  1 23      
Hansa

Registriert seit: 9. Jun 2002
Ort: Saarland
7.554 Beiträge
 
Delphi 8 Professional
 
#1

SQL - Parameter

  Alt 17. Feb 2003, 09:11
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:
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;
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. Wer weiß, was da fehlt oder falsch ist
Gruß
Hansa
  Mit Zitat antworten Zitat
Benutzerbild von Sharky
Sharky

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

Re: SQL - Parameter

  Alt 17. Feb 2003, 09:32
Zitat von Hansa:
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. Wer weiß, was da fehlt oder falsch ist
Hai Hansa,

hast Du denn den Parameter auch im OI angegeben (unter Params)?
Oder ihn im Code erzeugt?
Stephan B.
"Lasst den Gänsen ihre Füßchen"
  Mit Zitat antworten Zitat
Hansa

Registriert seit: 9. Jun 2002
Ort: Saarland
7.554 Beiträge
 
Delphi 8 Professional
 
#3

Re: SQL - Parameter

  Alt 17. Feb 2003, 09:37
Bei meinem DataSet gibts kein Params, zumindest nicht im OI.
Gruß
Hansa
  Mit Zitat antworten Zitat
Benutzerbild von Sharky
Sharky

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

Re: SQL - Parameter

  Alt 17. Feb 2003, 09:39
Zitat von Hansa:
Bei meinem DataSet gibts kein Params, zumindest nicht im OI.

Hmmm.... ich verwende die ADOs.... dort habe ich die bei den Querys und bei den DataSets.
Stephan B.
"Lasst den Gänsen ihre Füßchen"
  Mit Zitat antworten Zitat
oki

Registriert seit: 30. Dez 2002
Ort: Brandshagen
1.819 Beiträge
 
Delphi 2007 Professional
 
#5
  Alt 17. Feb 2003, 11:06
Hi Hansa,

wenn ich den Namen für den Pasameter nicht setzen möchte (Faulheit), schreibe ich folgendes:
MyQuery.Params[0].Value := KdNr; und die Abfrage wie Du sie geschrieben hast.

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:
KdNr := StrtoInt(Edit1.Text);
KuDS.SelectSQL.Text := 'SELECT * FROM KUNDE WHERE NR = '''+ KDNR +''';
Gruß oki
  Mit Zitat antworten Zitat
Lemmy

Registriert seit: 8. Jun 2002
Ort: Berglen
2.366 Beiträge
 
Delphi 10.3 Rio
 
#6

Re: SQL - Parameter

  Alt 17. Feb 2003, 11:38
Hi,
Zitat von Hansa:
Code:
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;
Oohhh Hansa, was soll das? Wie soll denn in Zeile 2 dem Parameter was zugewiesen werden, wenn Du in Zeile 3 die SQL-Anweisung änderst??? Dreh die beiden Zeilen um und versuchs nochmal. Wenn es nicht gehen sollte (aber nur dann) schiebe zwischen die beiden Zeilen ein

KuDS.Prepare

ein

Grüße
Lemmy
  Mit Zitat antworten Zitat
Hansa

Registriert seit: 9. Jun 2002
Ort: Saarland
7.554 Beiträge
 
Delphi 8 Professional
 
#7
  Alt 17. Feb 2003, 11:40
Zitat von oki:
Will ich keine Params verwenden, oder es gibt keine wie bei Dir
Das Bsp. mit dem Editfeld kann man so lösen, aber das ist hier nur aus Vereinfachungsgründen so einfach gehalten.
SQL-Code:
  
  KuDataSet.Params[0].Name := 'KDNR';
  KuDataSet.SelectSQL.Text := 'SELECT * FROM KUNDE WHERE NR = :KDNR';
So gehts auch nicht. Dann kommt : "Cannot assign to Read-Only property"
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.
Gruß
Hansa
  Mit Zitat antworten Zitat
Benutzerbild von MrSpock
MrSpock
(Co-Admin)

Registriert seit: 7. Jun 2002
Ort: Owingen
5.865 Beiträge
 
Delphi 2010 Professional
 
#8
  Alt 17. Feb 2003, 11:47
Hallo Hansa,

ich vermute, es liegt an der Reihenfolge.

Vor der Anweisung:

KuDataSet.SelectSQL.Text := 'SELECT * FROM KUNDE WHERE NR = :KDNR'; 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.
Albert
Live long and prosper


MrSpock
  Mit Zitat antworten Zitat
Hansa

Registriert seit: 9. Jun 2002
Ort: Saarland
7.554 Beiträge
 
Delphi 8 Professional
 
#9

Re: SQL - Parameter

  Alt 17. Feb 2003, 11:48
Zitat von Lemmy:
Oohhh Hansa, was soll das?
Das war mir schon klar, daß das irgendein Schwachsinn ist. Aber manchmal hat man halt Tomaten auf den Augen. 8) Lemmys Beitrag habe ich zu spät gesehen. Zeilen vertauscht und es geht Jetzt muß ich das ganze an dem eigentlichen Problem testen. Zumindest kann ich jetzt in dem Progrämmchen nachsehen, wie es richtig rum ist.

@MrSpock,Lemmy: Danke für die Hilfe. Da hatte ich echt einen Knoten im Gehirn.
Gruß
Hansa
  Mit Zitat antworten Zitat
Hansa

Registriert seit: 9. Jun 2002
Ort: Saarland
7.554 Beiträge
 
Delphi 8 Professional
 
#10
  Alt 17. Feb 2003, 20:33
Jetzt hänge ich wieder fest. Das ganze ging, aber jetzt nicht mehr bis zum Schluß.

Code:
        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 ));
was ist denn jetzt hier falsch ?

wieso beschwert sich Delphi : "Field ID not found" Bei den SQLs stehts richtig drin. So ein Mist !
Gruß
Hansa
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 1 von 3  1 23      


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 21:26 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