好得很程序员自学网

<tfoot draggable='sEl'></tfoot>

Oracle实现查询2个日期所跨过的月份列表/日期列表的方法分析

本文实例讲述了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

查看更多关于Oracle实现查询2个日期所跨过的月份列表/日期列表的方法分析的详细内容...

  阅读:23次