Re: Getting yyyy-mm-dd 00:00:00 in an arbitrary time zone

From: Tom Lane <tgl(at)sss(dot)pgh(dot)pa(dot)us>
To: "Davidson, Robert" <robdavid(at)amazon(dot)com>
Cc: pgsql-sql(at)postgresql(dot)org
Subject: Re: Getting yyyy-mm-dd 00:00:00 in an arbitrary time zone
Date: 2006-03-04 00:32:25
Message-ID: 9493.1141432345@sss.pgh.pa.us
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: pgsql-sql

"Davidson, Robert" <robdavid(at)amazon(dot)com> writes:
> I am trying to find out what the last full day of data for an arbitrary =
> timezone (generally not the pg client's timezone). I get the =
> max(timestamp), then would like to remove the time portion. Sounded like =
> a job for date_trunc, unfortunately date_trunc is not timezone aware:

> select (date_trunc('day', '2006-01-31 23:00:00-800' at time zone 'CST')) =
> at time zone 'CST'
> 2006-01-31 22:00:00-08

> Since the client is in PST, the truncated date is returned as 2006-02-01 =
> PST which is two hours before the desired time.

You're being quite unclear about what you want, but AFAICS the above
expression does exactly what you asked for. Namely, you get a time that
is midnight in the CST zone and then is adjusted to your current
timezone for display.

Perhaps you could be more clear about why you don't like this result?

regards, tom lane

In response to

Browse pgsql-sql by date

  From Date Subject
Next Message Davidson, Robert 2006-03-04 04:34:58 Re: Getting yyyy-mm-dd 00:00:00 in an arbitrary time zone
Previous Message Davidson, Robert 2006-03-04 00:13:04 Getting yyyy-mm-dd 00:00:00 in an arbitrary time zone