Delphi-PRAXiS

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Datenbanken (https://www.delphipraxis.net/15-datenbanken/)
-   -   Delphi Update mit Berechnung (https://www.delphipraxis.net/65857-update-mit-berechnung.html)

hsbc 21. Mär 2006 14:22

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

chaosben 21. Mär 2006 14:27

Re: Update mit Berechnung
 
Zitat:

Zitat von hsbc
Ich muss in meiner Datenbank den Inhalt des Feldes 'SALDO' von allen
UPDATE <Datenbank> SET SALDO = <neuer Wert> WHERE SALDO = <alter Wert>

Du bist schon ziemlich nah dran. Nur stören mich die beiden Bezugnahmen auf die Datenbank. Ersetz dies einfach mal durch den Begriff "Tabelle". Auf SQL ausgedrückt:
SQL-Code:
UPDATE <Tabelle> SET Saldo=<neuer Wert> WHERE Saldo=<alter Wert>

hsbc 21. Mär 2006 14:57

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

mkinzler 21. Mär 2006 15:00

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.

hsbc 21. Mär 2006 15:38

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

mkinzler 21. Mär 2006 16:08

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 17:43 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