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

生成一年中间隔几个月的表-Oracle

如何解决生成一年中间隔几个月的表-Oracle

我必须以以下格式创建表:-

TS_RANGE_BEGIN      TS_RANGE_END    
2019-01-01 17:00:00 2019-01-31 17:00:00  
2019-02-01 17:00:00 2019-02-28 17:00:00  
2019-03-01 17:00:00 2019-03-31 17:00:00

您能帮上忙吗?

谢谢

解决方法

看起来像一个简单的行生成器:

SQL> alter session set nls_date_format = 'yyyy-mm-dd hh24:mi:ss';

Session altered.

SQL> with std (datum) as
  2    (select to_date('01.01.2019 17:00','dd.mm.yyyy hh24:mi') from dual)
  3  select add_months(datum,level - 1) ts_range_begin,4         add_months(datum,level) - 1 ts_range_end
  5  from std
  6  connect by level <= 12;

TS_RANGE_BEGIN      TS_RANGE_END
------------------- -------------------
2019-01-01 17:00:00 2019-01-31 17:00:00
2019-02-01 17:00:00 2019-02-28 17:00:00
2019-03-01 17:00:00 2019-03-31 17:00:00
2019-04-01 17:00:00 2019-04-30 17:00:00
2019-05-01 17:00:00 2019-05-31 17:00:00
2019-06-01 17:00:00 2019-06-30 17:00:00
2019-07-01 17:00:00 2019-07-31 17:00:00
2019-08-01 17:00:00 2019-08-31 17:00:00
2019-09-01 17:00:00 2019-09-30 17:00:00
2019-10-01 17:00:00 2019-10-31 17:00:00
2019-11-01 17:00:00 2019-11-30 17:00:00
2019-12-01 17:00:00 2019-12-31 17:00:00

12 rows selected.

SQL>

STD CTE用于设置开始日期。

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