![]() |
Datenbank: Firebird • Version: 1.5.3 • Zugriff über: ZEOS
Update mit Berechnung
Hallo allerseits,
Ich muss in meiner Datenbank den Inhalt des Feldes 'SALDO' von allen Sätzen auf einen neuen Wert ändern, aber nur dann, wenn der bestehende Wert z.B. '100,55' beträgt. Gibt es hier die Möglichkeit, dass man diese Aufgabe der Datenbank selbst machen lässt oder muss man jeden Datensatz auslesen, prüfen, gegebenenfalls ändern und wieder zurückspeichern? Irgendwie dachte ich an einen Befehl wie: UPDATE <Datenbank> SET SALDO = <neuer Wert> WHERE SALDO = <alter Wert> Gibt es so etwas ähnliches oder muss man hier ev. Stored Procedures verwenden. Da das ganze nur ein einziges Mal gebraucht wird, wäre es mir natürlich lieber, wenn dies mit einer einfachen SQL-Anweisung möglich wäre. mfg Herbert |
Re: Update mit Berechnung
Zitat:
SQL-Code:
UPDATE <Tabelle> SET Saldo=<neuer Wert> WHERE Saldo=<alter Wert>
|
Re: Update mit Berechnung
Hallo chaosben,
danke vorerst mal für deine rasche Antwort. Ich habe das jetzt geändert. Meine Tabelle heisst KUNDEN. Die SQL-Anweisung lautet jetzt: UPDATE KUNDEN SET SALDO = <neuer Wert> WHERE SALDO = <alter Wert> im Klartext: 'UPDATE KUNDEN SET SALDO = ' + QuotedStr('123') + ' WHERE SALDO = ' + QuotedStr('222'); Wenn ich anschliessend mit ZQuery.ExecSQL öffne, kommt zwar keine Fehlermeldung, aber geändert wurde auch nichts. Wenn ich mit ZQuery.Open öffne, kommt die Fehlermeldung: Can not retrieve ResultSet data. Ich gehe davon aus, dass ich mit ZQuery.ExecSQL öffnen muss, nur verstehe ich nicht, dass keine Änderung durchgeführt wurde. Kann mir jemand vielleicht noch Tipps geben, was ich noch versuchen könnte, bzw. was ich hier falsch mache. mfg Herbert |
Re: Update mit Berechnung
Wie sind die Transaktionseinstellungen? autoCommit ? Sonst mußt du die Transaktion mit .Commit abschließen.
BTW wenn Saldo ein Float ist kannst du dir das Quoten sparen. Im Allgemeinen würde ich auf parametrisierte Abfragen umstellen. |
Re: Update mit Berechnung
Hallo,
Transaction ist auf autocommit. Ich glaube, ich habe die Ursache gefunden: Das Feld "SALDO" ist ein Textfeld, wobei die Anzeige rechtsbündig eingestellt ist. Ich vermute, dass in der Tabelle daher vor dem eigentlichen Wert ein oder mehrere Blanks vorhanden sind und daher mein Vergleich des gesamten Feldes dann nicht mehr stimmen kann. Gibt es in diesem Zusammenhang in SQL eine Anweisung, wo man die Blanks abschneiden kann, wie z.B. in Delphi TRIM. In etwa so: UPDATE <TABELLE> SET SALDO = <neuer Wert> WHERE TRIM(SALDO) = <alter Wert> mfg Herbert |
Re: Update mit Berechnung
genau so gehts.
BTW. Ich wüde das Feld Salso aber auf NUMERIC umstellen. |
Alle Zeitangaben in WEZ +1. Es ist jetzt 00:56 Uhr. |
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz