AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken FreePascal Datensatz Update Fehler?
Thema durchsuchen
Ansicht
Themen-Optionen

Datensatz Update Fehler?

Ein Thema von AlexII · begonnen am 16. Sep 2014 · letzter Beitrag vom 16. Sep 2014
Antwort Antwort
Seite 1 von 2  1 2      
AlexII

Registriert seit: 28. Apr 2008
1.717 Beiträge
 
FreePascal / Lazarus
 
#1

Datensatz Update Fehler?

  Alt 16. Sep 2014, 12:24
Datenbank: SQLite • Version: 3 • Zugriff über: Lazarus SQLite3Connection
Hallo,

was mache ich hier falsch? Komme irgendwie nicht drauf.

Delphi-Quellcode:
    SQLQuery1.Close;
    SQLQuery1.SQL.Text := 'UPDATE tbmain SET(:title, :start)';
    SQLQuery1.ParamByName('title').AsString := TitleEdit.Text;
    SQLQuery1.ParamByName('start').AsDateTime := StartDateEdit.Date;
    SQLQuery1.ExecSQL;
    SQLTransaction1.Commit;
Bin Hobbyprogrammierer! Meine Fragen beziehen sich meistens auf Lazarus!
  Mit Zitat antworten Zitat
Benutzerbild von baumina
baumina

Registriert seit: 5. Mai 2008
Ort: Oberschwaben
1.275 Beiträge
 
Delphi 11 Alexandria
 
#2

AW: Datensatz Update Fehler?

  Alt 16. Sep 2014, 12:27
Es fehlt ein where. Sollte die Datenbank trotzdem ein update ohne where zulassen, werden alle Datensätze upgedatet.
Hinter dir gehts abwärts und vor dir steil bergauf ! (Wolfgang Ambros)
  Mit Zitat antworten Zitat
Benutzerbild von DeddyH
DeddyH

Registriert seit: 17. Sep 2006
Ort: Barchfeld
27.540 Beiträge
 
Delphi 11 Alexandria
 
#3

AW: Datensatz Update Fehler?

  Alt 16. Sep 2014, 12:27
Ich kenne zwar SQLite nur dem Namen nach, aber die generelle UPDATE-Syntax ist
SQL-Code:
UPDATE
  Tabelle
SET
  Feld1 = Wert1,
  Feld2 = Wert2
WHERE
  Bedingung
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
AlexII

Registriert seit: 28. Apr 2008
1.717 Beiträge
 
FreePascal / Lazarus
 
#4

AW: Datensatz Update Fehler?

  Alt 16. Sep 2014, 12:31
Es fehlt ein where. Sollte die Datenbank trotzdem ein update ohne where zulassen, werden alle Datensätze upgedatet.
Stimmt 100pro... das kommt davon wenn man nicht ausgeschlafen ist.
Bin Hobbyprogrammierer! Meine Fragen beziehen sich meistens auf Lazarus!
  Mit Zitat antworten Zitat
Dejan Vu
(Gast)

n/a Beiträge
 
#5

AW: Datensatz Update Fehler?

  Alt 16. Sep 2014, 12:32
Wieso sollte eine Datenbank ein UPDATE ohne WHRE nicht zulassen? Wie will man den sonst 'alles auf 0' setzen? Ach so' update tabelle set alles=0 where 1=1'. klar.
  Mit Zitat antworten Zitat
Benutzerbild von DeddyH
DeddyH

Registriert seit: 17. Sep 2006
Ort: Barchfeld
27.540 Beiträge
 
Delphi 11 Alexandria
 
#6

AW: Datensatz Update Fehler?

  Alt 16. Sep 2014, 12:37
Außerdem ist
Zitat:
SET(:title, :start)
einfach syntaktisch falsch, woher soll denn das DBMS wissen, welche Felder die übergebenen Werte bekommen sollen?
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 baumina
baumina

Registriert seit: 5. Mai 2008
Ort: Oberschwaben
1.275 Beiträge
 
Delphi 11 Alexandria
 
#7

AW: Datensatz Update Fehler?

  Alt 16. Sep 2014, 12:39
[OT]Ich mag solche Suchspiele ... finde 10 Fehler [/OT]
Hinter dir gehts abwärts und vor dir steil bergauf ! (Wolfgang Ambros)
  Mit Zitat antworten Zitat
AlexII

Registriert seit: 28. Apr 2008
1.717 Beiträge
 
FreePascal / Lazarus
 
#8

AW: Datensatz Update Fehler?

  Alt 16. Sep 2014, 12:44
Außerdem ist
Zitat:
SET(:title, :start)
einfach syntaktisch falsch, woher soll denn das DBMS wissen, welche Felder die übergebenen Werte bekommen sollen?
Die hier, oder?

Delphi-Quellcode:
SQLQuery1.ParamByName('title').AsString := TitleEdit.Text;
SQLQuery1.ParamByName('start').AsDateTime := StartDateEdit.Date;
Wie wäre es richtig?
Bin Hobbyprogrammierer! Meine Fragen beziehen sich meistens auf Lazarus!
  Mit Zitat antworten Zitat
Benutzerbild von DeddyH
DeddyH

Registriert seit: 17. Sep 2006
Ort: Barchfeld
27.540 Beiträge
 
Delphi 11 Alexandria
 
#9

AW: Datensatz Update Fehler?

  Alt 16. Sep 2014, 12:47
Der Teil ist doch korrekt, aber Dein SQL nicht. Schau Dir doch #3 noch einmal an, da sind Datenbankfeld und dessen zu setzender Wert angegeben.
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
AlexII

Registriert seit: 28. Apr 2008
1.717 Beiträge
 
FreePascal / Lazarus
 
#10

AW: Datensatz Update Fehler?

  Alt 16. Sep 2014, 12:51
Hm... da kann ich nur rätseln... etwa so?

SQLQuery1.SQL.Text := 'UPDATE tbmain SET(:title = title, :start = start) WHERE id=i';
Bin Hobbyprogrammierer! Meine Fragen beziehen sich meistens auf Lazarus!
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 1 von 2  1 2      


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 20:32 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