Re: Date trunc in UTC - Mailing list pgsql-sql

From Thrasher
Subject Re: Date trunc in UTC
Date
Msg-id 3DDDF4AD.8030105@fibers.upc.es
Whole thread Raw
In response to Date trunc in UTC  (Thrasher <thrasher@fibers.upc.es>)
Responses Re: Date trunc in UTC  (Tom Lane <tgl@sss.pgh.pa.us>)
List pgsql-sql
The biggest point that I see is that it would be nice to have some kind 
of function that works with UTC values, regarding of which timezone the 
user has set. Let's say, something like

SELECT UTC_DATE_TRUNC ('month', NOW ());
     utc_date_trunc
------------------------ 2002-11-01 01:00:00+01

because if you work with international applications, the beggining of 
the month in Spain should be the same as in Australia. But everyone will 
see it in its own timezone.

I think that it would be also interesting to have the UTCeed versions of 
EXTRACT and AGE.


Tom Lane wrote:
> Richard Huxton <dev@archonet.com> writes:
> 
>>Hmm - good point. You can revert to the client default but not to the
>>previous value. I don't know of any way to read these SET values
>>either - a quick poke through pg_proc didn't show anything likely.
> 
> 
> In 7.3 you can use current_setting() and set_config() to access SHOW/SET
> functionality.  However, I agree with your suggestion of AT TIME ZONE
> to rotate a timestamp into a target timezone, rather than mucking with
> the TimeZone setting.
> 
> 
> BTW, Thomas: is AT TIME ZONE supposed to accept
> timestamp-without-timezone input?  If so, what's it supposed to do with
> it?  The current behavior seems unintuitive to say the least:
> 
> regression=# select now();
>               now
> -------------------------------
>  2002-11-21 10:19:14.591001-05
> (1 row)
> 
> regression=# select now() at time zone 'UTC';
>           timezone
> ----------------------------
>  2002-11-21 15:19:18.588279
> (1 row)
> 
> regression=# select localtimestamp;
>          timestamp
> ----------------------------
>  2002-11-21 10:19:22.629865
> (1 row)
> 
> regression=# select localtimestamp at time zone 'UTC';
>            timezone
> -------------------------------
>  2002-11-21 05:19:26.178861-05
> (1 row)
> 
> It seems to me that the last case should give either an error or
> 2002-11-21 15:19:26.178861 (ie, assume that the timestamp without time
> zone is in my TimeZone zone).  In any case, surely the result should
> be of type timestamp WITHOUT time zone?
> 
>             regards, tom lane
> 
> 



pgsql-sql by date:

Previous
From: Dan Langille
Date:
Subject: connectby questions
Next
From: Dan Langille
Date:
Subject: Re: connectby questions