问题描述
嗨,汤姆,
我有一个问题,假设我选择两个日期范围 “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
你能帮忙吗
我有一个问题,假设我选择两个日期范围 “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进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。