Re: Fields float4 don't return any row when selecting a value with a .

From: Bruno Wolff III <bruno(at)wolff(dot)to>
To: "Francisco Figueiredo Jr(dot)" <fxjrlists(at)yahoo(dot)com(dot)br>
Cc: pgsql-hackers(at)postgresql(dot)org
Subject: Re: Fields float4 don't return any row when selecting a value with a .
Date: 2003-06-18 03:31:55
Message-ID: 20030618033155.GB7805@wolff.to
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: pgsql-hackers

On Tue, Jun 17, 2003 at 23:26:07 -0300,
"Francisco Figueiredo Jr." <fxjrlists(at)yahoo(dot)com(dot)br> wrote:
>
>
> Hi all,
> I'm using the 7.4 cvs version on cygwin and I noticed that if I have a
> table with a field of float4 type and try to do a simple select:
> select * from table where field_float4 = 4.4
>
> it doesn't return any rows.
> In the same table I have a float8 field and it works ok.
>
> If I try with a value without the . in the float4 field it also works.

I believe that is because the constant 4.4 is originally a float 8 value
and the comparison to the float4 value is done by promoting to float8.
And the nearest float4 value to 4.4 is not the same as the nearest
float8 value to 4.4. I think both quoting the 4.4 or casting it to
float4 will solve your problem.

Note that under many circumstances equality tests between floating
values doesn't make a lot of sense. If you really want to do this,
you might want to consider using the numeric type.

In response to

Responses

Browse pgsql-hackers by date

  From Date Subject
Next Message Christopher Kings-Lynne 2003-06-18 03:44:07 lots of configure failures on freebsd/alpha
Previous Message Francisco Figueiredo Jr. 2003-06-18 02:26:07 Fields float4 don't return any row when selecting a value with a .