AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi sql - update-befehl - zur Lauzeit
Thema durchsuchen
Ansicht
Themen-Optionen

sql - update-befehl - zur Lauzeit

Ein Thema von markon · begonnen am 16. Okt 2003 · letzter Beitrag vom 27. Okt 2003
Antwort Antwort
markon

Registriert seit: 12. Sep 2003
229 Beiträge
 
#1

sql - update-befehl - zur Lauzeit

  Alt 16. Okt 2003, 10:27
hallo.
beschäftige mich mit "update"
Delphi-Quellcode:
var i:byte;
begin
  i:=5;
 DM_Tabelle.adoquery1.sql.Text:= 'update tabelle1 set TorDiff = (:i) where TorDiff is NULL';
 DM_Tabelle.adoquery1.ExecSQL;
end;
die spalte TorDiff soll mit dem BeispielsWert i gefüllt werden. Später soll zur Laufzeit statt i ein berechneter Wert stehen.

es kommt keine fehlermeldung wenn ich den befehl ausführe. aber es wird auch nix gemacht. die spalte ist danach genau so leer wie vorher.

wer kann mir helfen?
  Mit Zitat antworten Zitat
OLLI_T

Registriert seit: 13. Okt 2003
Ort: Nähe Wetzlar / Hessen
143 Beiträge
 
Delphi 5 Enterprise
 
#2

Re: sql - update-befehl - zur Lauzeit

  Alt 16. Okt 2003, 10:32
HY Du!

Probiers mal damit:

DM_Tabelle.adoquery1.sql.Text:= Format('update tabelle1 set TorDiff = %d where TorDiff is NULL',[i]);

Gruss

OLLI
No Pain No Gain!
  Mit Zitat antworten Zitat
st2000

Registriert seit: 23. Apr 2003
Ort: Hamburg
52 Beiträge
 
Delphi 5 Enterprise
 
#3

Re: sql - update-befehl - zur Lauzeit

  Alt 16. Okt 2003, 10:34
Müsstest Du da nicht mit den Params von TAdoQuery arbeiten ? Einfach so in den Text reinschreiben, hilft der Komponente ja noch nicht dabei, zwischen der Variablen i und dem reinen Stringbestandteil '...(:i)...' zu unterscheiden. Wenn Dein Feld TorDiff ein Textfeld ist, müsste Du es ja in Quotes stecken '...'(:i)'...'; dann hättest Du aber nicht den WERT i=5 drin, sondern wirklich (:i).
In der OH müsste die Arbeit mit Parametern (Params) beschrieben sein.

Gruss, ST2000
Stefan
Keine Softwarepatente ! Die Polen = wahre Freiheitskämpfer !!! Gerade noch rechtzeitig Mitglied geworden, um die Notbremse zu ziehen. Year !!!
  Mit Zitat antworten Zitat
Benutzerbild von hEiHaChI
hEiHaChI

Registriert seit: 30. Jul 2003
Ort: Potsdam
8 Beiträge
 
Delphi 5 Enterprise
 
#4

Re: sql - update-befehl - zur Lauzeit

  Alt 16. Okt 2003, 10:37
Moin,

wie wärs mit:

DM_Tabelle.adoquery1.sql.Text:= 'update tabelle1 set TorDiff = '+inttostr(i)+' where TorDiff is NULL';
  Mit Zitat antworten Zitat
markon

Registriert seit: 12. Sep 2003
229 Beiträge
 
#5

Re: sql - update-befehl - zur Lauzeit

  Alt 16. Okt 2003, 10:40
@ OLLI_T
danke für deine schnelle hilfe. funktioniert!
Delphi-Quellcode:
DM_Tabelle.adoquery1.sql.Text:=
  Format('update tabelle1 set TorDiff = %d where TorDiff is NULL',[i]);
diese schreibweise ist mir völlig unklar
was bewirkt z.B. diese %d ??
das mit dem [i] leuchtet mir ja noch ein..
  Mit Zitat antworten Zitat
markon

Registriert seit: 12. Sep 2003
229 Beiträge
 
#6

Re: sql - update-befehl - zur Lauzeit

  Alt 16. Okt 2003, 11:00
@ hEiHaChI

danke für deine lösung. diese verstehe ich auf anhieb und funktionieren tut sie auch.
thx
  Mit Zitat antworten Zitat
InSys

Registriert seit: 20. Okt 2003
Ort: Erfurt/Thüringen
8 Beiträge
 
#7

Re: sql - update-befehl - zur Lauzeit

  Alt 27. Okt 2003, 00:52
Man könnte das so machen , ist vorallem bei vielen Feldern übersichtlicher

Delphi-Quellcode:
  With AdsQuery2 do Begin
   Try
    close;Sql.Clear;
    Sql.Add('Update Dict_43000 set Umschreibung= :P0 , P = :P1 Where RowID = '+ZeileVar );
    Params[0].Value:=EditDlg.Memo1.Text;
    Params[1].Value:=PVar;
    execsql;
   Except

   end;
  end;
[edit=Christian Seehase]BB-Codes aktiviert. Bitte das Profil mal dahingehend überprüfen. Danke. Mfg, Christian Seehase[/edit]
  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 16:13 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