首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何将时区应用于查询

如何将时区应用于查询
EN

Stack Overflow用户
提问于 2019-11-13 04:16:00
回答 1查看 41关注 0票数 0

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

代码语言:javascript
复制
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,

我需要使用“在时区‘美国/东部’”,但我不能成功。谢谢

EN

回答 1

Stack Overflow用户

发布于 2019-11-13 05:35:51

原则上,您可以使用FROM_TZ

代码语言:javascript
复制
FROM_TZ(sysdate, 'US/Eastern') 

FROM_TZ只接受TIMESTAMP值,因此必须使用

代码语言:javascript
复制
FROM_TZ(CAST(sysdate AS TIMESTAMP), 'US/Eastern') 

但是,只有当您的数据库服务器的操作系统的时区实际上是‘美国/东部’时,结果才是正确的。如果您运行CAST(SYSDATE AS TIMESTAMP WITH TIME ZONE,那么Oracle将使用您当前的SESSIONTIMEZONE,它可能与您的数据库服务器操作系统的时区不同。

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

代码语言:javascript
复制
SYSTIMESTAMP AT TIME ZONE 'US/Eastern'
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/58826046

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档