Delphi-PRAXiS
Seite 2 von 2     12   

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Datenbanken (https://www.delphipraxis.net/15-datenbanken/)
-   -   Feld enthält falschen Wert (https://www.delphipraxis.net/167782-feld-enthaelt-falschen-wert.html)

bwolf 18. Apr 2012 11:12

AW: Feld enthält falschen Wert
 
Super vielen Dank!

sx2008 19. Apr 2012 00:15

AW: Feld enthält falschen Wert
 
Zitat:

Zitat von mkinzler (Beitrag 1162460)
In anderen DBMS gibt es neben Float noch NUMERIC/DECIMAL. Hier kann man die Anzahl der relevanten Stellen festlegen

Das Problem ist nur, dass es in Delphi keinen dazu passenden Datentyp gibt.
"Currency" (64Bit) hat genau 4 Nachkommastellen.
Leider gibt es keinen "Decimal"-Datentyp mit 128Bit wie z.B. in dot-Net.

Eine Kunde von uns handelt mit Elektronikbauteilen.
Nun ist ein einzelner SMD Widerstand so billig, dass 5 Nachkommastellen benötigt werden.
Tja, geht halt nicht; Double bzw. Extended machen Rundungsfehler und Currency reicht nicht aus.
Hier sollte Embacadero unbedingt mit den Mitbewerbern gleichziehen.

himitsu 19. Apr 2012 00:37

AW: Feld enthält falschen Wert
 
Currency ist ein nativer Typ in der FPU, so wie Single, Double und teilweise auch Extended.
Darauf hatte Borland/Codegear/Embarcadero keinen Einfluß.
Und die 64 Bit entsprechen auch der Auflösung (signifikante Stellen) des Extended, welches in der FPU die größte Auflösung darstellt.

Was da die 64-Bit-CPU oder sowas wie MMX bieten, weiß ich allerdings nicht genau.

mkinzler 19. Apr 2012 08:07

AW: Feld enthält falschen Wert
 
Zitat:

Das Problem ist nur, dass es in Delphi keinen dazu passenden Datentyp gibt.
Das ist hier auch irrelevant. Es ging ja auch um den Typ des Datenbankfeldes

Iwo Asnet 19. Apr 2012 08:56

AW: Feld enthält falschen Wert
 
Zitat:

Zitat von mkinzler (Beitrag 1162612)
Zitat:

Das Problem ist nur, dass es in Delphi keinen dazu passenden Datentyp gibt.
Das ist hier auch irrelevant. Es ging ja auch um den Typ des Datenbankfeldes

Bedingt, denn wie bekommt man die vom Feld gebotene Genauigkeit mit Delphi hinein? Soll man dann zu den Sprachen wechseln, die BCD o.ä. können?

mkinzler 19. Apr 2012 09:26

AW: Feld enthält falschen Wert
 
Das Problem liegt an der Ungenauigkeit der Fliesskommazahlen. In seinem Fall würde sein Problem so vermieden.

himitsu 19. Apr 2012 09:46

AW: Feld enthält falschen Wert
 
Mir ist so, als wenn ich im Delphi mal einen BCD-Typen gesehen hätte, aber bei seinem kleinen Wert absolut unnötig. (da würde sogar Single reichen)

BoolString 19. Apr 2012 10:55

AW: Feld enthält falschen Wert
 
Klassiker auf dem Gebiet der Gleitkomma-Arithmetik sind die Arbeiten von Goldberg, Monniaux und die eigentliche Spezifikation IEEE 754.

Alle findet man relativ häufig frei im Netz. Z.B.:

Goldberg, What every computer scientist should know about floating point arithmetic.
Monniaux, The pitfalls of verifying floating point computations.
IEEE754 in der deutschsprachigen Wikipedia.

Ich kenn mich mit Datenbanken nicht so aus, aber entsprechende Ungenauigkeiten kommen oftmals zustande, wenn Variablen unterschiedlichen Typs miteinander verrechnet werden, Zwischenergebnisse in anderen Variablen gespeichert werden, etc.

Jan


Alle Zeitangaben in WEZ +1. Es ist jetzt 17:20 Uhr.
Seite 2 von 2     12   

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