AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi Fehler in SQL bei Update
Thema durchsuchen
Ansicht
Themen-Optionen

Fehler in SQL bei Update

Ein Thema von Hansi · begonnen am 23. Dez 2005 · letzter Beitrag vom 23. Dez 2005
Antwort Antwort
Hansi

Registriert seit: 8. Okt 2004
271 Beiträge
 
#1

Fehler in SQL bei Update

  Alt 23. Dez 2005, 10:26
Datenbank: MySQL • Version: 4,1 • Zugriff über: Zeos
Hey,

Ich finde einfach nicht den Fehler. Er meldet mir immer dass er "in der Nähe" von Hersteller_ID einen Fehler in der Syntax findet. (Schön für Ihn )

Delphi-Quellcode:
    ...
    SQL.Clear;
    SQL.Text := 'UpDate HERSTELLER SET HERSTELLER = "'+ Edit1.Text + '" '+
                  ', WEBSITE = "'+ Edit2.Text + '", GELOESCHT = "N", Where HERSTELLER_ID = "' + sPosNr + '"';
    ExecSQL;
    ...
Tabelle: Hersteller
Felder: Hersteller (VarChar), Hersteller_id (Int), Website (VarChar), Geloescht (Enum)

sPosNr = "IntToStr(integer Zahl)"

Was mache ich falsch?
  Mit Zitat antworten Zitat
alex517

Registriert seit: 23. Nov 2004
Ort: Bernau b. Berlin
273 Beiträge
 
Delphi XE5 Enterprise
 
#2

Re: Fehler in SQL bei Update

  Alt 23. Dez 2005, 10:37
Hi

   Where HERSTELLER_ID = "' + sPosNr + '"'; wenn HERSTELLER_ID ein Integer ist solltest du die (") weglassen.

alex
Alexander
  Mit Zitat antworten Zitat
Benutzerbild von Sharky
Sharky

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

Re: Fehler in SQL bei Update

  Alt 23. Dez 2005, 10:42
Hai Hansi,

ich habe mir angewöhnt nur noch mit Parametern zu arbeiten. Da muss ich mich nicht darum kümmern das die Werte "richtig formatiert" ankommen.

In deinem Fall könnte das dann so aussehen:
Delphi-Quellcode:
    ...
    SQL.Clear;
    SQL.Text := 'UpDate HERSTELLER SET HERSTELLER = :phersteller, WEBSITE = :pwebsite, GELOESCHT = "N" ' + #10
        ' Where HERSTELLER_ID = :phersteller_id';
    SQL.ParamCheck := True;
    SQL.ParamByName ('phersteller').AsString := Edit1.Text;
    SQL.ParamByName ('pwebsite').AsString := Edit2.Text
    SQL.ParamByName ('phersteller_id').AsInteger := integer_zahl;
    ExecSQL;
    ...
Stephan B.
"Lasst den Gänsen ihre Füßchen"
  Mit Zitat antworten Zitat
Hansi

Registriert seit: 8. Okt 2004
271 Beiträge
 
#4

Re: Fehler in SQL bei Update

  Alt 23. Dez 2005, 11:02
Habe den Fehler gefunden! Es lag an der Zeilentrennung mit dem "+" und den Kommas dazwischen! Die Felder werden mit KOmmas getrennt. Vor der WHERE Klausel darf kein "," mehr stehen!


Delphi-Quellcode:
    SQL.Clear;
    SQL.Text := 'UpDate HERSTELLER SET HERSTELLER = "'+ Edit1.Text + '", WEBSITE = "'+ Edit2.Text + '", GELOESCHT = "N" Where HERSTELLER_ID = "' + sPosNr + '"';
    ExecSQL;
Vielen Dank für eure Hilfe!

Schöne Weihnachten 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 06:04 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