AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi Variablen als Parameter übergeben?
Thema durchsuchen
Ansicht
Themen-Optionen

Variablen als Parameter übergeben?

Ein Thema von Loki77 · begonnen am 27. Feb 2006 · letzter Beitrag vom 27. Feb 2006
Antwort Antwort
Seite 1 von 2  1 2      
Benutzerbild von Loki77
Loki77

Registriert seit: 21. Feb 2006
Ort: Trier
132 Beiträge
 
Delphi XE2 Enterprise
 
#1

Variablen als Parameter übergeben?

  Alt 27. Feb 2006, 10:49
Datenbank: Paradox • Version: 7 • Zugriff über: Query
Morgen!
Wie kann ich den Inhalt von zwei Edit-komponenten als Parameter in
eine Query-Komponente übergeben?
Mal allgemein:
Delphi-Quellcode:
procedure TfrmMain.AddClick(Sender: TObject);
begin
qryMain.Close;
qryMain.SQL.Clear;
// Hier die Query Anweisung:
qryMain.SQL.Add('UPDATE Tabelle SET Feld1 =??? , Feld2 =??? );
// (parameter0) (parameter1)

qryMain.Params[0].DataType := ftInteger;
qryMain.Params[1].DataType := ftInteger;
qryMain.Params[0].AsInteger := StrToInt(edtFeld1.Text);
qryMain.Params[1].AsInteger := StrToInt(edtFeld2.Text);
qryMain.ExecSQL;
qryMain.Close;
qryMain.SQL.Clear;
qryMain.SQL.Add(
'SELECT Feld1, Feld2 FROM Tabelle;');
qryMain.Open;
DBGrid1.Refresh;
end;
Brauche nur die Syntax für die Query-Anweisung.
Frage: Muss die Parameter-Definition VOR der Anweisung stehen?
Gruss + Danke, Loki.
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

Registriert seit: 9. Dez 2005
Ort: Heilbronn
39.858 Beiträge
 
Delphi 11 Alexandria
 
#2

Re: Variablen als Parameter übergeben?

  Alt 27. Feb 2006, 10:58
Delphi-Quellcode:
qryMain.SQL.Add('UPDATE Tabelle SET Feld1 =:feld1, Feld2 = :feld2' );
qryMain.ParamByName('feld1').Value bzw as<Typ> (asInteger)

Zitat:
Frage: Muss die Parameter-Definition VOR der Anweisung stehen?
danach, sonst findert er sie nicht!
Markus Kinzler
  Mit Zitat antworten Zitat
Benutzerbild von Loki77
Loki77

Registriert seit: 21. Feb 2006
Ort: Trier
132 Beiträge
 
Delphi XE2 Enterprise
 
#3

Re: Variablen als Parameter übergeben?

  Alt 27. Feb 2006, 11:11
Danke, wird so gehen.
Aber wie funktioniert die übergabe mit Parameter By Index,
nicht ParamByName?
Loki.
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

Registriert seit: 9. Dez 2005
Ort: Heilbronn
39.858 Beiträge
 
Delphi 11 Alexandria
 
#4

Re: Variablen als Parameter übergeben?

  Alt 27. Feb 2006, 11:18
qryMain.Params.Items[0].Value; bzw as<Typ>; .
die verkürzte Form qryMain.Params[0].Value müsste aber auch gehen.
Markus Kinzler
  Mit Zitat antworten Zitat
Benutzerbild von Loki77
Loki77

Registriert seit: 21. Feb 2006
Ort: Trier
132 Beiträge
 
Delphi XE2 Enterprise
 
#5

Re: Variablen als Parameter übergeben?

  Alt 27. Feb 2006, 11:21
Ja, das war mir klar, aber wie sieht das in der Query-Anweisung aus?
(muss mich mal klarer ausdrücken....)
Gruss Loki.
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

Registriert seit: 9. Dez 2005
Ort: Heilbronn
39.858 Beiträge
 
Delphi 11 Alexandria
 
#6

Re: Variablen als Parameter übergeben?

  Alt 27. Feb 2006, 11:22
Genauso.
Markus Kinzler
  Mit Zitat antworten Zitat
Benutzerbild von Loki77
Loki77

Registriert seit: 21. Feb 2006
Ort: Trier
132 Beiträge
 
Delphi XE2 Enterprise
 
#7

Re: Variablen als Parameter übergeben?

  Alt 27. Feb 2006, 11:30
Also
Delphi-Quellcode:
qryMain.SQL.Add('UPDATE Tabelle SET Feld1, Feld2' );
qryMain.Params[0].DataType := ftInteger;
qryMain.Params[1].DataType := ftInteger;
qryMain.Params[0].AsInteger := StrToInt(edtFeld1.Text);
qryMain.Params[1].AsInteger := StrToInt(edtFeld2.Text);
???

Loki
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

Registriert seit: 9. Dez 2005
Ort: Heilbronn
39.858 Beiträge
 
Delphi 11 Alexandria
 
#8

Re: Variablen als Parameter übergeben?

  Alt 27. Feb 2006, 11:34
Nein so
Delphi-Quellcode:
qryMain.SQL.Add('UPDATE Tabelle SET Feld1= :feld1, Feld2 = :feld2' );
qryMain.Params[0].DataType := ftInteger; //Nicht unbedingt notwendig
qryMain.Params[1].DataType := ftInteger; //Nicht unbedingt notwendig
qryMain.Params[0].asString := edtFeld1.Text;
qryMain.Params[1].asString := edtFeld2.Text;
Wie du die Parameter benennst ist in diesem Fall egal könnte auch :f1, :a oder :djajsdhadajks sein.
Markus Kinzler
  Mit Zitat antworten Zitat
Benutzerbild von Loki77
Loki77

Registriert seit: 21. Feb 2006
Ort: Trier
132 Beiträge
 
Delphi XE2 Enterprise
 
#9

Re: Variablen als Parameter übergeben?

  Alt 27. Feb 2006, 11:38
OK, das war das Problem.Warum dann überhaupt Namen.....
Klappt aber, DANKE!!!
Gruss Loki.
  Mit Zitat antworten Zitat
Benutzerbild von SirThornberry
SirThornberry
(Moderator)

Registriert seit: 23. Sep 2003
Ort: Bockwen
12.235 Beiträge
 
Delphi 2006 Professional
 
#10

Re: Variablen als Parameter übergeben?

  Alt 27. Feb 2006, 11:40
und wie würde das dann aussehen wenn ich in 2 felder den gleichen wert haben will bzw. nicht in der Reihenfolge der params? also so:
SQL-Code:
qryMain.SQL.Add('UPDATE Tabelle SET Feld1= :feld2, Feld2 = :feld1' );
qryMain.Params[0].DataType := ftInteger; //Nicht unbedingt notwendig
qryMain.Params[1].DataType := ftInteger; //Nicht unbedingt notwendig
qryMain.Params[0].asString := edtFeld1.Text;
qryMain.Params[1].asString := edtFeld2.Text;
bzw so:
SQL-Code:
qryMain.SQL.Add('UPDATE Tabelle SET Feld1= :feld1, Feld2 = :feld2, Feld3 = :feld1' );
qryMain.Params[0].DataType := ftInteger; //Nicht unbedingt notwendig
qryMain.Params[1].DataType := ftInteger; //Nicht unbedingt notwendig
qryMain.Params[0].asString := edtFeld1.Text;
qryMain.Params[1].asString := edtFeld2.Text;
Jens
Mit Source ist es wie mit Kunst - Hauptsache der Künstler versteht's
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 1 von 2  1 2      


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 06:54 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