本文实例讲述了Oracle实现查询2个日期所跨过的月份列表/日期列表的方法。分享给大家供大家参考,具体如下:
1.基本逻辑公式:
Select Rownum, 开始日期+Rownum-1 from dual connect by rownum< 结束日期-开始日期 +2;
2.查询2个日期所跨过的日期yyyy-mm-dd列表:
查询结果:
SQL代码(开始时间:2019-01-22,结束时间:2019-01-02):
1
2
3
|
Select Rownum, to_date( '2019-01-02' , 'yyyy-mm-dd' )+Rownum-1 from dual connect by rownum< to_date( '2019-01-22' , 'yyyy-mm-dd' )-to_date( '2019-01-02' , 'yyyy-mm-dd' ) +2; |
3.查询2个日期所跨过的月份yyyy-mm列表:
查询结果:
SQL代码(开始时间:2020-03-15,结束时间:2019-01-02):
1
2
3
4
5
|
select ss.DAY_ID from ( SELECT TO_CHAR(TO_DATE( '2019-01-02' , 'YYYY-MM-DD' )+ROWNUM-1 , 'YYYY-MM' ) DAY_ID from dual connect by rownum< to_date( '2020-03-15' , 'yyyy-mm-dd' )-to_date( '2019-01-02' , 'yyyy-mm-dd' ) +2 ) ss GROUP BY DAY_ID ORDER BY DAY_ID |
希望本文所述对大家Oracle数据库程序设计有所帮助。
原文链接:https://blog.csdn.net/yqwang75457/article/details/87857503