如何将时区应用于查询

时间:2019-11-12 20:16:00

标签: sql oracle

我有这个查询,谁给了我“上周”的开始日期和结束日期。

to_char(trunc(sysdate-7, 'iw'),'YYYY-MM-DD')  as week_start,
to_char(trunc(sysdate-7, 'iw') + interval '6' day, 'YYYY-MM-DD') as week_end,

我需要使用“在美国/东部时区”,但是我没有成功。 谢谢

1 个答案:

答案 0 :(得分:1)

原则上,您可以使用FROM_TZ

FROM_TZ(sysdate, 'US/Eastern') 

FROM_TZ仅接受一个TIMESTAMP值,因此您必须使用

FROM_TZ(CAST(sysdate AS TIMESTAMP), 'US/Eastern') 

但是,仅当数据库服务器操作系统的时区实际上是“美国/东部”时,结果才是正确的。如果您运行CAST(SYSDATE AS TIMESTAMP WITH TIME ZONE,则Oracle将采用您当前的SESSIONTIMEZONE,这可能与数据库服务器操作系统的时区不同。

有一个更简单的解决方案,只需使用:

SYSTIMESTAMP AT TIME ZONE 'US/Eastern'