Re: BUG #3607: timestamp is behaving strangely - Mailing list pgsql-bugs

From Tom Lane
Subject Re: BUG #3607: timestamp is behaving strangely
Date
Msg-id 21900.1189198406@sss.pgh.pa.us
Whole thread Raw
In response to BUG #3607: timestamp is behaving strangely  ("Cade Cairns" <cadec@otii.com>)
List pgsql-bugs
"Cade Cairns" <cadec@otii.com> writes:
> test=> select '2007-05-11 09:33:01.167885'::timestamp without time zone,
> ('epoch'::timestamp without time zone + '1178875981.167885
> seconds'::interval)::timestamp without time zone;
>          timestamp          |         timestamp
> ----------------------------+----------------------------
>  2007-05-11 09:33:01.167885 | 2007-05-11 09:33:01.167885
> (1 row)

> test=> select '2007-05-11 09:33:01.167885'::timestamp without time zone =
> ('epoch'::timestamp without time zone + '1178875981.167885
> seconds'::interval)::timestamp without time zone;
>  ?column?
> ----------
>  f
> (1 row)

If you're using floating-point timestamps (which is the default build)
you are up against the limit of accuracy of a standard float8 value.
IOW that's not really exactly 09:33:01.167885, but close to it.
Checking this example shows that the two float timestamps internally
are 232191181.16788501 and 232191181.16788507.

            regards, tom lane

pgsql-bugs by date:

Previous
From: "Cade Cairns"
Date:
Subject: BUG #3607: timestamp is behaving strangely
Next
From: "LIZETH ANGHELA SIRPA CACERES"
Date:
Subject: HELP URGENTE