AGB  ·  Datenschutz  ·  Impressum  







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

SQL UPDATE will nicht

Ein Thema von Privateer3000 · begonnen am 28. Nov 2012 · letzter Beitrag vom 4. Okt 2013
Antwort Antwort
Seite 1 von 3  1 23      
Benutzerbild von Privateer3000
Privateer3000

Registriert seit: 10. Jun 2002
Ort: Jena
1.128 Beiträge
 
Delphi 10.4 Sydney
 
#1

SQL UPDATE will nicht

  Alt 28. Nov 2012, 15:39
Datenbank: Firebird • Version: 2.1 • Zugriff über: ZEOS7
Hallöchen,
ich steh grad irgendwie aufm Schlauch:
folgendes update:
Code:
try
    v_ma:='Passwort1';
    v_ta:='Passwort2';
     ug:=TStringList.Create;
     systemquer.Active:=True;
     systemquer.Edit;
      ug.Add('update SYSTEM set MPASSWORT='+v_ma+',TAPASS='+v_ta+' where ID=1');
      sysupdate.ModifySQL:=ug; { TODO 1 -oIch -cSQL : Update vervollständigen }
       try
         systemquer.Post;
         systemquer.Refresh;
       except
         Showmessage('Speichern fehlgeschlagen!');
       end;
  finally
    ug.Free;
    systemquer.Active:=False;
  end;
produziert folgende Fehlermeldung:
Code:
Execute, proto: firebird-2.1, msg: Dynamic SQL Error SQL error code = -206 Column unknown Passwort1 At line 1, column 29, errcode: -206, error: Column does not belong to referenced table The SQL: update SYSTEM set MPASSWORT=Passwort1,TAPASS=Passwort2 where ID=1
Wieso soll Passwort1 "Column unknown" sein?
Ich hab es auch ohne Update-Kompo probiert (dyn. Query)

Was passiert da?
Peter
+++Versuch es nicht mit Gewalt + Nimm einen größeren Hammer! +++
  Mit Zitat antworten Zitat
Benutzerbild von DeddyH
DeddyH

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

AW: SQL UPDATE will nicht

  Alt 28. Nov 2012, 15:42
Da fehlen die Anführungszeichen, es handelt sich ja wohl um Strings. Wieso benutzt Du keine SQL-Parameter, abgesehen von den Sicherheitsaspekten sind solche Probleme damit auch gleich vom Tisch?
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
Benutzerbild von Privateer3000
Privateer3000

Registriert seit: 10. Jun 2002
Ort: Jena
1.128 Beiträge
 
Delphi 10.4 Sydney
 
#3

AW: SQL UPDATE will nicht

  Alt 28. Nov 2012, 16:06
Weil ich nicht weiß wie bei der TZUpdateSQL von ZEOS
Parameter übergeben werden.
Params.ParamByName('XY') werden nicht akzeptiert.

Wie diese Parameter eingesetzt werden, hab ich keine Dok gefunden.
Man kan zur Laufzeit wie auch zu Entwicklerzeit diese setzen.
aber wie?
Bei der TZQuery geht das einwandfrei
Code:
with ug do begin
     Close; SQL.Clear;
     SQL.Text:='update SYSTEM set MPASSWORT = :MA,TAPASS = :TA where ID=1';
      ParamByName('MA').Value:=v_ma;
      ParamByName('TA').Value:=v_ta;
       try
         ExecSQL;
       except
         Showmessage('Speichern fehlgeschlagen!');
       end;
      end;
das funktioniert auch.
Peter
+++Versuch es nicht mit Gewalt + Nimm einen größeren Hammer! +++
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

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

AW: SQL UPDATE will nicht

  Alt 28. Nov 2012, 16:09
Die Parameter werden automatisch mit den Werten, welche du in die Felder schreibst, belegt.
Markus Kinzler
  Mit Zitat antworten Zitat
Benutzerbild von Privateer3000
Privateer3000

Registriert seit: 10. Jun 2002
Ort: Jena
1.128 Beiträge
 
Delphi 10.4 Sydney
 
#5

AW: SQL UPDATE will nicht

  Alt 28. Nov 2012, 16:13
Die Parameter werden automatisch mit den Werten, welche du in die Felder schreibst, belegt.
Sondern?
Ich seh da einfach nicht durch.
Die Doks zu ZEOS sind so lückenhaft.
Wie muss denn die Paramter-gedingse zur Laufzeit denn aussehen?
Peter
+++Versuch es nicht mit Gewalt + Nimm einen größeren Hammer! +++
  Mit Zitat antworten Zitat
Benutzerbild von DeddyH
DeddyH

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

AW: SQL UPDATE will nicht

  Alt 28. Nov 2012, 16:14
Mit ZEOS kenne ich mich nicht aus, aber laut Tutorial im DT soll es auch beim TZUpdateSQL Parameter geben.
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
 
#7

AW: SQL UPDATE will nicht

  Alt 28. Nov 2012, 16:16
Delphi-Quellcode:
DataSet.Edit;
DataSet.FieldByName(<Feld>).Value := <Wert>;
->
Entsprechender Wert in Parameter des UpdateSQL wird gesetzt.
DataSet.Post; ->
UpdateSQL.ExecuteSQL; wird ausgeführt

http://www.delphi-treff.de/tutorials...d/tzupdatesql/
Markus Kinzler

Geändert von mkinzler (28. Nov 2012 um 16:18 Uhr)
  Mit Zitat antworten Zitat
Lemmy

Registriert seit: 8. Jun 2002
Ort: Berglen
2.381 Beiträge
 
Delphi 10.4 Sydney
 
#8

AW: SQL UPDATE will nicht

  Alt 28. Nov 2012, 16:23
Was dir Markus sagen will: Verwende TUpdateSQL nicht direkt sondern immer in Verbindung mit einer TQUery. Dort solltest DU im Objektinspektor die Möglichkeit haben eine TUpdateSQL-Instanz zu hinterlegen.

WEnn Du nun in der TQuery deinen Select hast (Select * from X where ID=:ID) und in der TUpdateSQL die dazugehörigen DML-Befehle (die ggf. auch automatisch anhand der Select erzeugt werden), dann arbeitest Du ganz einfach mit der Query:

Delphi-Quellcode:
  Query.OPen;
  Query.Update;
  Query.FieldByName('eins').AsString := 'eins';
  Query.Post;
und die Query und TUpdateSQL übernehmen den REst.
  Mit Zitat antworten Zitat
Benutzerbild von p80286
p80286

Registriert seit: 28. Apr 2008
Ort: Stolberg (Rhl)
6.659 Beiträge
 
FreePascal / Lazarus
 
#9

AW: SQL UPDATE will nicht

  Alt 28. Nov 2012, 16:32
Abgesehen von dem bisher geschriebenen,
was haben systemquer und sysupdate miteinander zu tun?

Delphi-Quellcode:
try
  v_ma:='Passwort1';
  v_ta:='Passwort2';
  ug:=TStringList.Create;
  systemquer.Active:=True;
  systemquer.Edit;
  ug.Add('update SYSTEM set MPASSWORT='+v_ma+',TAPASS='+v_ta+' where ID=1');

  sysupdate.ModifySQL:=ug; { TODO 1 -oIch -cSQL : Update vervollständigen }

  try
    systemquer.Post;
    systemquer.Refresh;
  except
     Showmessage('Speichern fehlgeschlagen!');
  end;
  finally
    ug.Free;
    systemquer.Active:=False;
  end;
Gruß
K-H
Programme gehorchen nicht Deinen Absichten sondern Deinen Anweisungen
R.E.D retired error detector
  Mit Zitat antworten Zitat
Benutzerbild von Privateer3000
Privateer3000

Registriert seit: 10. Jun 2002
Ort: Jena
1.128 Beiträge
 
Delphi 10.4 Sydney
 
#10

AW: SQL UPDATE will nicht

  Alt 28. Nov 2012, 18:26
Vielen Dank für Eure Antworten!

sysupdate ist eine TZUpdateSQL und bammelt
an der systemquer (TZQuery) dran.
Das funktioniert normalerweise.
Nur das Parameterdingenskirchen verstehe ich nicht.
Ich werde die Posts mal durchgehen.
Peter
+++Versuch es nicht mit Gewalt + Nimm einen größeren Hammer! +++
  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 03:24 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