Re: [ADMIN] float4
От | Don Garrett |
---|---|
Тема | Re: [ADMIN] float4 |
Дата | |
Msg-id | 3777DB76.DEF7B64E@bgb-consulting.com обсуждение исходный текст |
Ответ на | float4 (JT Kirkpatrick <jt-kirkpatrick@mpsllc.com>) |
Список | pgsql-sql |
You shouldn't use a float at all for exact amounts. Floats handle arbitrary precision, but do it rounding off values somewhat. The way the round off works is based on the (base 2) internal representation and so it never quite seems to make sense in decimal. It's possible on some machines/float formats to have "if (1.0 + 1.0 = 2.0)" evaluate to false. When I first started programming, I did a very simple custom accounting package using floats.... and had to go back and rewrite all of it. You will do better to use integers (no rounding at all) and consider the contents to be the number of pennies involved, not dollars. JT Kirkpatrick wrote: > > we have a database (linux, 6.4.2, new odbc, connections from msaccess / > win98) -- access doesn't fully appreciate the monetary type in postgres, so > we made all monetary fields FLOAT4's. weird stuff -- or maybe not to you > -- we insert 23516.69 into a float4 field directly in psql, and then select > it, and it shows 23516.7. this is not good for a field used for MONEY!!! > what are the limitations of float4? should i have used float8? > > thanks for any help you can offer. . . > > jt -- Don Garrett dgarrett@acm.org BGB Consulting http://www.bgb-consulting.com/garrett
В списке pgsql-sql по дате отправления: