微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

sql – 将2个月添加到当前时间戳

如何在Oracle中为时间戳值添加月份?在我的查询中,它转换为日期值而不是:
SELECT add_months(current_timestamp,2) 
     FROM   dual;

实际输出是:

ADD_MONTH
     11-MAR-13

预期的输出是:

2013-01-01 00:00:00.000000000+00:00

解决方法

这将为您提供TIMESTAMP数据类型的日期和时间:
select TO_TIMESTAMP(TO_CHAR(ADD_MONTHS(SYSDATE,2),'YYYYMMDD HH24:MI'),'YYYYMMDD HH24:MI') from dual;

如果您需要比上述更高或更低的精度(E.G.舍入),请调整日期格式(两者都需要采用相同的格式).例如,这将返回2个月到秒的精度级别:

select TO_TIMESTAMP(TO_CHAR(ADD_MONTHS(SYSTIMESTAMP,'YYYYMMDD HH24:MI:SS'),'YYYYMMDD HH24:MI:SS') from dual;

这是我能得到的最接近你需要的格式(作为一个角色):

select TO_CHAR( 
TO_TIMESTAMP(TO_CHAR(ADD_MONTHS(SYSTIMESTAMP,'YYYY-MM-DD HH24:MI:SS'),'YYYY-MM-DD HH24:MI:SS.FF TZR') from dual;

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐