暂无图片
暂无图片
暂无图片
暂无图片
暂无图片

Oracle 减去2个时间戳以找到小时的差异

askTom 2017-02-14
360

问题描述

嗨,

如何找出2个时间戳与时区之间的时差

我试过低于一个
select 
extract(HOUR FROM diff) from (
select '2/14/2017 3:39:15.097484 PM +00:00' - '2/14/2017 1:39:15.097484 PM +00:00' as diff from dual);

[Error] Execution (49: 19): ORA-30076: invalid extract field for extract source

复制

专家解答

你依赖于隐式转换!

显式地将字符串转换为带有时区的时间戳,一切都应该是笨拙的dory:

select extract(hour from diff) hrs from (
select 
  to_timestamp_tz('2/14/2017 3:39:15.097484 PM +00:00', 'mm/dd/yyyy hh:mi:ssxff PM tzh:tzm') -
  to_timestamp_tz('2/14/2017 1:39:15.097484 PM +00:00', 'mm/dd/yyyy hh:mi:ssxff PM tzh:tzm') diff
from dual
);

HRS  
2    
复制

「喜欢这篇文章,您的关注和赞赏是给作者最好的鼓励」
关注作者
【版权声明】本文为墨天轮用户原创内容,转载时必须标注文章的来源(墨天轮),文章链接,文章作者等基本信息,否则作者和墨天轮有权追究责任。如果您发现墨天轮中有涉嫌抄袭或者侵权的内容,欢迎发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。

评论