AGB  ·  Datenschutz  ·  Impressum  







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

Update mit Datum

Ein Thema von daNiii · begonnen am 22. Mär 2010 · letzter Beitrag vom 22. Mär 2010
Antwort Antwort
daNiii

Registriert seit: 10. Nov 2008
98 Beiträge
 
Turbo Delphi für Win32
 
#1

Update mit Datum

  Alt 22. Mär 2010, 15:05
Datenbank: Microsoft access 2007 • Zugriff über: sql
Liebe Programmierer,
In folgenden Programmiercode habe ich die Variable Heute (tdatetime) diese wird mit dem Wert NOW deklariert und soll in der Datenbank gespeichert werden.
Der Updatebefehl ist jedoch fehlerhaft.

Delphi-Quellcode:
procedure TForm2.Button1Click(Sender: TObject);
var
Heute: tdatetime;
begin
if cb_dublikat.Checked = true then
begin
showmessage('Dublikat wird gedruckt');
end else begin
Heute:= now();

adoquery1.close;
adoquery1.sql.clear;
adoquery1.sql.Add('select * from Lieferscheine where Lieferschein ="'+makierterLieferschein+'"');
adoquery1.open;

if adoquery1.FieldValues['RDatum'] > 1 then begin
 
adoquery1.close;
adoquery1.sql.clear;
adoquery1.sql.Add('update from Lieferscheine set RDatum = '+datetostr(Heute)+' where Lieferschein ="'+makierterLieferschein+'"');
adoquery1.execsql;
adoquery1.close;



end else begin
If Messagedlg('Diese Rechnung wurde bereits ausgegeben. Möchten Sie ein Dublikat ausstellen?', mtConfirmation, [mbYes,mbNo],0) = mrYes then
begin
showmessage('Dublikat wird gedruckt');
end;
end;
end;



end;
  Mit Zitat antworten Zitat
Benutzerbild von DelphiBandit
DelphiBandit

Registriert seit: 19. Feb 2007
Ort: bei Walsrode
165 Beiträge
 
Delphi 10.4 Sydney
 
#2

Re: Update mit Datum

  Alt 22. Mär 2010, 15:15
Zitat von daNiii:
adoquery1.sql.Add('update from Lieferscheine set RDatum = '+datetostr(Heute)+' where Lieferschein ="'+makierterLieferschein+'"');
Setz mal um Dein Datum auch das doppelte Anführungszeichen, wie Du es hinten bei makierterLieferschein (fehlt ein r) auch machst. Bei Firebird-Datenbanken zumindest muß ein Datum als String-Variable übergeben werden.
Carsten
  Mit Zitat antworten Zitat
Benutzerbild von Bernhard Geyer
Bernhard Geyer

Registriert seit: 13. Aug 2002
17.171 Beiträge
 
Delphi 10.4 Sydney
 
#3

Re: Update mit Datum

  Alt 22. Mär 2010, 15:18
Und hier mein täglicher TIPP:

VERWENDE PARAMETRISIERTE INSERTS!

Und schon lösen sich solche und ähnliche Codierungsproblem in Luft auf.
Windows Vista - Eine neue Erfahrung in Fehlern.
  Mit Zitat antworten Zitat
ele

Registriert seit: 18. Feb 2009
129 Beiträge
 
Delphi 2010 Professional
 
#4

Re: Update mit Datum

  Alt 22. Mär 2010, 15:24
Zitat von Bernhard Geyer:
Und hier mein täglicher TIPP:

VERWENDE PARAMETRISIERTE INSERTS!

Und schon lösen sich solche und ähnliche Codierungsproblem in Luft auf.
Und man hat zusätzlich den Vorteil, dass man sich keine Sorgen mehr über SQL-Injections machen muss...

Edit: Und es heisst übrigens "Duplikat" nicht "Dublikat".
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

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

Re: Update mit Datum

  Alt 22. Mär 2010, 15:29
Und auch nicht um das Datumsformat, ist schneller bei mehrfachen Upadtes/Inserts
Markus Kinzler
  Mit Zitat antworten Zitat
shmia

Registriert seit: 2. Mär 2004
5.508 Beiträge
 
Delphi 5 Professional
 
#6

Re: Update mit Datum

  Alt 22. Mär 2010, 17:30
Hier ist ein from zuviel; das dürfte dein Syntaxproblem sein.
adoquery1.sql.Add('update from Lieferscheine set RDatum = '..
Andreas
  Mit Zitat antworten Zitat
daNiii

Registriert seit: 10. Nov 2008
98 Beiträge
 
Turbo Delphi für Win32
 
#7

Re: Update mit Datum

  Alt 22. Mär 2010, 18:33
Danke!
Nachdem ich das from weggegeben habe, hat es funktioniert.
Außerdem danke, dass ihr mich auf meinen Rechtschreibfehler aufmerksam gemacht habt.
LG
  Mit Zitat antworten Zitat
Benutzerbild von haentschman
haentschman

Registriert seit: 24. Okt 2006
Ort: Seifhennersdorf / Sachsen
5.292 Beiträge
 
Delphi 12 Athens
 
#8

Re: Update mit Datum

  Alt 22. Mär 2010, 19:01
Hallo...

das es funktioniert ist ja schön... aber mit Parametern hast du dich nicht auseinandergesetzt ?

  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 23:47 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