bug in interval/extract or am I abusing interval()? - Mailing list pgsql-general

From Chris Green
Subject bug in interval/extract or am I abusing interval()?
Date
Msg-id m2d7369vgp.fsf@phosphorus.tucc.uab.edu
Whole thread Raw
List pgsql-general
I'm using postgresql-7.1.3 and I'm trying to keep track of uptimes for
various devices by using an interval data type.

I've done some test cases and the way interval works with 'integer
seconds' is different from the way it acts with a raw int.  I notice
that there is no interval(int) function.

How can one tell which function converted to?


* Seem the same but they are oddly different representations.

      select interval(31900879);

             interval
      ------------------------
       1 year 4 days 05:21:19


      select interval('31900879 seconds');

           interval
      -------------------
       369 days 05:21:19


* Represenations really bite me here

          select interval('31900879 seconds') - interval(31900879);
            ?column?
      --------------------
       -1 years +365 days



* more tests....

select extract(epoch from interval('31900879 seconds'));
 date_part
-----------
  31900879

select extract(epoch from interval(31900879));
 date_part
-----------
  31900879

test_network=# select extract(epoch from interval(31900879));
 date_part
-----------
  31922479
(1 row)

 select extract(epoch from interval('31900879 seconds')) -
        extract(epoch from interval(31900879));
 ?column?
----------
   -21600

--
Chris Green <cmg@uab.edu>
To err is human, to moo bovine.

pgsql-general by date:

Previous
From: nickh@one.net (Nick)
Date:
Subject: PostgresSQL 7.x Oracle8 Comparison
Next
From: "Andy Hallam"
Date:
Subject: PsqlODBC and SQLDescribeCol