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

Oracle 生成日期范围

askTom 2018-06-16
216

问题描述

嗨,汤姆,
我有一个问题,假设我选择两个日期范围 “2014年6月10日” 和 “2018年6月10日”,那么我希望输出像
10-6月-2014至10-6月-2015
10-6月-2015至10-6月-2016
10-6月-2016至10-6月-2017
10-6月-2017至10-6月-2018

你能帮忙吗

专家解答

我们可以使用连接技巧生成行

SQL> create table t ( dfrom date, dto date );

Table created.

SQL>
SQL> insert into t values ( date '2014-06-10', date '2018-06-10' );

1 row created.

SQL>
SQL> select add_months(dfrom,12*(rownum-1))
  2  from t
  3  connect by add_months(dfrom,12*(rownum-1)) <= dto;

ADD_MONTH
---------
10-JUN-14
10-JUN-15
10-JUN-16
10-JUN-17
10-JUN-18

5 rows selected.
复制


所以我们只是操纵它来得到我们的答案。

SQL> select
  2    add_months(dfrom,12*(rownum-1)),
  3    add_months(dfrom,12*rownum)
  4  from t
  5  connect by add_months(dfrom,12*(rownum-1)) < dto;

ADD_MONTH ADD_MONTH
--------- ---------
10-JUN-14 10-JUN-15
10-JUN-15 10-JUN-16
10-JUN-16 10-JUN-17
10-JUN-17 10-JUN-18
复制


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

评论