Oracle日期按年拆分,日期按月拆分SQL

该博客介绍了如何使用Oracle SQL进行日期的按年和按月拆分。提供了两个查询示例,第一个例子展示了如何将日期范围按完整年度进行拆分,第二个例子则演示了如何按月份进行详细拆分。每个拆分的区间都包含了起始和结束日期,对于按年拆分,输出了每年的开始和结束日期;对于按月拆分,输出了每个月的起始和结束日期。
摘要由CSDN通过智能技术生成

Oracle日期按年拆分,日期按月拆分SQL

日期按年拆分

SELECT

(LEVEL - 1) as k

,extract(YEAR FROM start_date)+(LEVEL - 1) start_year

,extract(YEAR FROM end_date) end_year

,decode(extract(YEAR FROM start_date),extract(YEAR FROM start_date)+(LEVEL - 1),start_date,add_months(trunc(start_date, 'YYYY'), (LEVEL-1)*12)) start_date

,decode(extract(YEAR FROM end_date),extract(YEAR FROM start_date)+(LEVEL - 1),end_date,add_months(trunc(start_date, 'YYYY'), LEVEL*12) -1) end_date

  FROM (SELECT to_date('2019-09-16','YYYY-MM-DD') AS end_date

            ,to_date('2018-04-11','YYYY-MM-DD') AS start_date

         FROM dual)

CONNECT BY LEVEL <= (extract(YEAR FROM end_date) - extract(YEAR FROM start_date)) + 1;

输出结果

KSTART_YEAREND_YEARSTART_DATEEND_DATE
10201820192018/4/112018/12/31
21201920192019/1/12019/9/16

日期按月拆分

SELECT decode(to_char(trunc(start_date_m

                       ,'MM')

                  ,'YYYY-MM')

           ,to_char(trunc(add_months(start_date_m

                                ,(LEVEL - 1))

                       ,'MM')

                  ,'YYYY-MM')

           ,start_date_m

           ,trunc(add_months(start_date_m

                          ,(LEVEL - 1))

                ,'MM')) new_start_date

     ,decode(to_char(trunc(end_date_m

                       ,'MM')

                  ,'YYYY-MM')

           ,to_char(trunc(add_months(start_date_m

                                ,(LEVEL - 1))

                       ,'MM')

                  ,'YYYY-MM')

           ,end_date_m

           ,last_day(add_months(start_date_m

                            ,(LEVEL - 1)))) new_end_date

     ,to_char(trunc(add_months(start_date_m

                          ,(LEVEL - 1))

                 ,'MM')

            ,'YYYY-MM') year_month_x1

     ,start_date_m

     ,end_date_m

  FROM ((SELECT to_date('2018-12-31'

                   ,'YYYY-MM-DD') AS end_date_m

             ,to_date('2018-04-11'

                   ,'YYYY-MM-DD') AS start_date_m

          FROM dual))

CONNECT BY LEVEL <= (extract(MONTH FROM end_date_m) - extract(MONTH FROM start_date_m)) + 1;

输出结果

NEW_START_DATENEW_END_DATEYEAR_MONTH_X1START_DATE_MEND_DATE_M
12018/4/112018/4/30  2018-042018/4/112018/12/31
22018/5/12018/5/31  2018-052018/4/112018/12/31
32018/6/12018/6/30  2018-062018/4/112018/12/31
42018/7/12018/7/31  2018-072018/4/112018/12/31
52018/8/12018/8/31  2018-082018/4/112018/12/31
62018/9/12018/9/30  2018-092018/4/112018/12/31
72018/10/12018/10/31  2018-102018/4/112018/12/31
82018/11/12018/11/30  2018-112018/4/112018/12/31
92018/12/12018/12/31  2018-122018/4/112018/12/31

--刘轶鹤 

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值