AGB  ·  Datenschutz  ·  Impressum  







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

Sql Abfrage

Ein Thema von benny · begonnen am 25. Mai 2008 · letzter Beitrag vom 25. Mai 2008
Antwort Antwort
benny

Registriert seit: 24. Mai 2008
16 Beiträge
 
#1

Sql Abfrage

  Alt 25. Mai 2008, 17:17
untere Select-Anweisung
close;
sql.clear;
sql.add('Select NameBez from PersonStam where PersonId=PersonNr');
open;
liefert mir beim Ausführen des Programms die Fehlermeldung "ungültiger Feldname: PersonNr". Die Variable "PersonNr" ist definiert (Typ string) und mit einen Wert belegt. Ersetze ich "PersonNr" durch einen statischen Wert, funktioniert sie einwandfrei. Was ist falsch dabei ?

benny
  Mit Zitat antworten Zitat
Benutzerbild von Matze
Matze
(Co-Admin)

Registriert seit: 7. Jul 2003
Ort: Schwabenländle
14.929 Beiträge
 
Turbo Delphi für Win32
 
#2

Re: Sql Abfrage

  Alt 25. Mai 2008, 17:19
Hallo,

es müsste sicher so heißen:

sql.add('Select NameBez from PersonStam where PersonId=' + PersonNr); Grüße
  Mit Zitat antworten Zitat
grenzgaenger
(Gast)

n/a Beiträge
 
#3

Re: Sql Abfrage

  Alt 25. Mai 2008, 17:20
Zitat von benny:
untere Select-Anweisung
close;
sql.clear;
sql.add('Select NameBez from PersonStam where PersonId=PersonNr');
open;
liefert mir beim Ausführen des Programms die Fehlermeldung "ungültiger Feldname: PersonNr". Die Variable "PersonNr" ist definiert (Typ string) und mit einen Wert belegt. Ersetze ich "PersonNr" durch einen statischen Wert, funktioniert sie einwandfrei. Was ist falsch dabei ?

benny
ps: setze doch deinen code in DELPHI tags

zu deinem problem, hier hast du zwei möglichkeiten

a) du verwendest variablen
Delphi-Quellcode:
close;
sql.clear;
sql.add('Select NameBez from PersonStam where PersonId=:PersonNr');
open;
oder b)
du konvertierst das erst mal in 'n ordentliches format, z.b. bei 'n string:
Delphi-Quellcode:
close;
sql.clear;
sql.add('Select NameBez from PersonStam where PersonId=' + quotedstr(PersonNr) + ';');
open;
oder bei einer zahl:
Delphi-Quellcode:
close;
sql.clear;
sql.add('Select NameBez from PersonStam where PersonId=' + inttostr(PersonNr) + ';');
open;
  Mit Zitat antworten Zitat
Benutzerbild von DeddyH
DeddyH

Registriert seit: 17. Sep 2006
Ort: Barchfeld
27.625 Beiträge
 
Delphi 12 Athens
 
#4

Re: Sql Abfrage

  Alt 25. Mai 2008, 17:28
Wobei Lösung a) vorzuziehen ist
Detlef
"Ich habe Angst vor dem Tag, an dem die Technologie unsere menschlichen Interaktionen übertrumpft. Die Welt wird eine Generation von Idioten bekommen." (Albert Einstein)
Dieser Tag ist längst gekommen
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

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

Re: Sql Abfrage

  Alt 25. Mai 2008, 17:29
Und man redet von (SQL-)Parametern
Markus Kinzler
  Mit Zitat antworten Zitat
benny

Registriert seit: 24. Mai 2008
16 Beiträge
 
#6

Re: Sql Abfrage

  Alt 25. Mai 2008, 17:43
muss auch die Query entsprechend angepasst werden, die meckert nämlich jetzt "Typ für Feld PersonNr unbekannt", bin recht frisch in Deplhi !!
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

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

Re: Sql Abfrage

  Alt 25. Mai 2008, 17:45
Du musst den Parameter auch setzen:
Delphi-Quellcode:
close;
sql.clear;
sql.add('Select NameBez from PersonStam where PersonId=:PersonNr');
ParamByName('PersonNR').Value := PersonNr;
open;
Markus Kinzler
  Mit Zitat antworten Zitat
Benutzerbild von DeddyH
DeddyH

Registriert seit: 17. Sep 2006
Ort: Barchfeld
27.625 Beiträge
 
Delphi 12 Athens
 
#8

Re: Sql Abfrage

  Alt 25. Mai 2008, 17:46
Du musst den Inhalt des Parameters noch bekannt machen:
Delphi-Quellcode:
Query.close;
Query.sql.clear;
Query.sql.add('Select NameBez from PersonStam where PersonId=:PersonNr');
Query.ParamByName('PersonNr').AsString := PersonNr;
Query.open;
Detlef
"Ich habe Angst vor dem Tag, an dem die Technologie unsere menschlichen Interaktionen übertrumpft. Die Welt wird eine Generation von Idioten bekommen." (Albert Einstein)
Dieser Tag ist längst gekommen
  Mit Zitat antworten Zitat
benny

Registriert seit: 24. Mai 2008
16 Beiträge
 
#9

Re: Sql Abfrage

  Alt 25. Mai 2008, 17:53
das funktioniert eiwandfrei, DANKE euch allen !!!
  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 11:49 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