AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Feld enthält falschen Wert
Thema durchsuchen
Ansicht
Themen-Optionen

Feld enthält falschen Wert

Ein Thema von bwolf · begonnen am 18. Apr 2012 · letzter Beitrag vom 19. Apr 2012
Antwort Antwort
Seite 1 von 2  1 2      
bwolf

Registriert seit: 17. Jan 2006
368 Beiträge
 
Delphi 2009 Professional
 
#1

Feld enthält falschen Wert

  Alt 18. Apr 2012, 10:02
Datenbank: Advantage Databse • Version: 10 • Zugriff über: Advantage Delphi Components
Hi,

ich habs folgendes Problem:

Ich weise einer TQuery einen Wert zu:

Code:
qQuery.FieldByName('Feld').AsFloat := (Wert1 + Wert2 - Wert3); //
Die Variablen Wert1 Wert2 und Wert3 sind alle vom Typ Double und haben laut Debugger die Werte 3,9, 0 und 4.
Nach der Zuweisung enthält qQuery.FieldByName('Feld') den Wert -0.1.
Nach dem Post allerdings steht in der Datenbank Der Wert -0,0999999999999996

Was ich festgestellt habe:
Die Variable Wert1 bekommt ihren Wert aus der Datenbank zugewiesen:
Code:
Wert1 := Query.FieldByName('Feld').asFloat
Der zugewiesen Wert aus der Datenbank ist tatsächlich 3.9 (zeigt mit zumindest die Datenbank an)

Wenn ich den Wert von Variable Wert1 im Code auf 3.9 setze, dann funktioniert stimmt alles:

Code:
Wert1 := 3.9;
qQuery.FieldByName('Feld').AsFloat := (Wert1 + Wert2 - Wert3);
Ich stehe da grad ziemlich auf dem schlauch, irgendjemand zeigt mir hier doch falsche Werte an
Hat jemand eine Idee?

danke euch!
  Mit Zitat antworten Zitat
Benutzerbild von DeddyH
DeddyH

Registriert seit: 17. Sep 2006
Ort: Barchfeld
27.624 Beiträge
 
Delphi 12 Athens
 
#2

AW: Feld enthält falschen Wert

  Alt 18. Apr 2012, 10:06
Das sind doch ganz normale Rundungsungenauigkeiten im Zusammenhang mit Fließkommazahlen. Wenn Du es genauer brauchst, käme evtl. eine Änderung des Feldtyps in Currency in Betracht?
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
mkinzler
(Moderator)

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

AW: Feld enthält falschen Wert

  Alt 18. Apr 2012, 10:07
Fließkommazahlen haben implementationsbedingt eine Ungenauigkeit. Um dies zu vermeiden, schreibe am Besten auf x Stelle gerundete Werte in die DB.

Btw. der Cast mit .asFloat ist unnötig. Nimm besser .Value
Markus Kinzler
  Mit Zitat antworten Zitat
bwolf

Registriert seit: 17. Jan 2006
368 Beiträge
 
Delphi 2009 Professional
 
#4

AW: Feld enthält falschen Wert

  Alt 18. Apr 2012, 10:12
Hi und danke für die schnellen Antworten.
Ich frage mich trotzdem warum der Debugger mit nicht die exakten Werte anzeigt? Das ist ziemlich verwirrend wenn man es nicht weiß...
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

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

AW: Feld enthält falschen Wert

  Alt 18. Apr 2012, 10:18
Der Debugger rundet. Ich kenne mich mit ADS nicht so aus. In anderen DBMS gibt es neben Float noch NUMERIC/DECIMAL. Hier kann man die Anzahl der relevanten Stellen festlegen
Markus Kinzler
  Mit Zitat antworten Zitat
bwolf

Registriert seit: 17. Jan 2006
368 Beiträge
 
Delphi 2009 Professional
 
#6

AW: Feld enthält falschen Wert

  Alt 18. Apr 2012, 10:22
Ah ok gut zu wissen...
Ja der ADS bietet auch den Datentyp numeric bei dem die Stellen festgelegt weren können.

Das Feld war fälschlicher Weise als Double angelegt was natürlich falsch war, das wird nun geändert.

Thx!
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

Registriert seit: 11. Okt 2003
Ort: Elbflorenz
44.080 Beiträge
 
Delphi 12 Athens
 
#7

AW: Feld enthält falschen Wert

  Alt 18. Apr 2012, 10:24
Der Debugger nutzt sowas wie FloatToStr für die Anzeige und das nicht mit der maximalen möglichen Anzahl an signifikanten Stellen.
Man dachte sich wohl "lieber etwas gerundet, aber dafür leichter zu lesen".

PS: Darum gibt es Typen wie Delphi-Referenz durchsuchenCurrency und in DBs Felder mit festen Nachkommastellen, um die Rundungsprobleme zu minimieren/abzuschaffen.
Neuste Erkenntnis:
Seit Pos einen dritten Parameter hat,
wird PoSex im Delphi viel seltener praktiziert.
  Mit Zitat antworten Zitat
bwolf

Registriert seit: 17. Jan 2006
368 Beiträge
 
Delphi 2009 Professional
 
#8

AW: Feld enthält falschen Wert

  Alt 18. Apr 2012, 11:00
So ich muß nun doch nochmal blöd nachfragen:

In der Datenbank stehen ja definitiv die Werte 3,9, 0 , 4 die ich den Variablen in Delphi zuweise.
Wie kann es dann sein das bei der Berechunung (Wert1 + Wert2 - Wert3) dann -0,0999999999999996 und nicht -0.1 rauskommt?
  Mit Zitat antworten Zitat
jobo

Registriert seit: 29. Nov 2010
3.072 Beiträge
 
Delphi 2010 Enterprise
 
#9

AW: Feld enthält falschen Wert

  Alt 18. Apr 2012, 11:07
Wer berechnet das denn?
Dein Code oben hat mit DB nichts zu tun, die Rechnung macht der Client. Und hier greifen dann Effekte, die ja schon angedeutet wurden, eben Fließkommaarithmetik. Die Typen zu ändern wurde ja bereits vorgeschlagen.

Hast Du das Problem auch, wenn Du es mit einem Update Statement in einer SQL Console durchführst? Wenn nicht, dann führ doch die Op auf dem Server aus.
Gruß, Jo
  Mit Zitat antworten Zitat
Benutzerbild von Luckie
Luckie

Registriert seit: 29. Mai 2002
37.621 Beiträge
 
Delphi 2006 Professional
 
#10

AW: Feld enthält falschen Wert

  Alt 18. Apr 2012, 11:10
Hier ist die Erklärung: http://www.michael-puff.de/Programmi...esskomma.shtml
Michael
Ein Teil meines Codes würde euch verunsichern.
  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 01:21 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