| From: | Tomasz Ostrowski <tometzky(at)batory(dot)org(dot)pl> | 
|---|---|
| To: | Ow Mun Heng <ow(dot)mun(dot)heng(at)wdc(dot)com> | 
| Cc: | pgsql-general(at)postgresql(dot)org | 
| Subject: | Re: Interval Formatting -> Convert to timestamp | 
| Date: | 2008-08-21 09:53:22 | 
| Message-ID: | 48AD3B12.9030401@batory.org.pl | 
| Views: | Whole Thread | Raw Message | Download mbox | Resend email | 
| Thread: | |
| Lists: | pgsql-general | 
On 2008-08-21 11:09, Ow Mun Heng wrote:
> I want to find out if there's a method to change this
> select to_char('1 day 09:18:42.37996'::interval,'HH24:MI:SS')
> to something like
> 24+9(hours) = 33:18:42 instead of returning It as 09:19:42
That's because 1 day doesn't always have 24 hours, because there are
daylight saving times. 1 month can also have various number of days or
hours.
If you want 1 day to be always 24 hours then:
select date_part('day', t)*'24h'::interval + t-date_trunc('day',t)
from (select '1 day 09:18:42.37996'::interval as t) as s;
It will not work for intervals with months. I'm not sure for negative ones.
Regards
Tometzky
-- 
...although Eating Honey was a very good thing to do, there was a
moment just before you began to eat it which was better than when you
were...
                                                      Winnie the Pooh
| From | Date | Subject | |
|---|---|---|---|
| Next Message | Ow Mun Heng | 2008-08-21 11:33:34 | Re: Interval Formatting -> Convert to timestamp | 
| Previous Message | Vishal Arora | 2008-08-21 09:39:43 | Re: Regarding access to a user |