Oracle
 sql >> Base de données >  >> RDS >> Oracle

Conversion de fuseau horaire dans une requête SQL

Vous pouvez utiliser cette requête sans avoir à vous soucier des changements de fuseau horaire.

select to_char(cast(application_recv_date as timestamp) at time zone 'US/Eastern',
               'MON dd, YYYY'
              )
from application;

Ex :

HAE :

select cast(date'2014-04-08' as timestamp) d1,
       cast(date'2014-04-08' as timestamp) at time zone 'US/Eastern' d2
from dual;

D1                                 D2
---------------------------------- -------------------------------------------
08-APR-14 12.00.00.000000 AM       07-APR-14 08.00.00.000000 PM US/EASTERN

HNE :

select cast(date'2014-12-08' as timestamp) d1,
       cast(date'2014-12-08' as timestamp) at time zone 'US/Eastern' d2
from dual;

D1                                 D2
---------------------------------- -------------------------------------------
08-DEC-14 12.00.00.000000 AM       07-DEC-14 07.00.00.000000 PM US/EASTERN

MISE À JOUR :

Merci à Alex Poole d'avoir rappelé que, lorsque le fuseau horaire n'est pas spécifié, le fuseau horaire local est utilisé pour la conversion.

Pour forcer la date à être reconnue comme GMT, utilisez from_tz.

from_tz(cast(date'2014-12-08' as timestamp), 'GMT') at time zone 'US/Eastern'