ORACLE 根据时间段取的所有 月---周 分组统计 月份周和自然周、月

获取日期列表:

SELECT TO_CHAR(TO_DATE('2014-10-01', 'yyyy-MM-dd') + ROWNUM - 1, 'yyyyMMdd') as daylist  
  FROM DUAL  
CONNECT BY ROWNUM <=  
           trunc(to_date('2015-06-01', 'yyyy-MM-dd') -  
                 to_date('2014-10-01', 'yyyy-MM-dd')) + 1  

获取月份列表:

SELECT TO_CHAR(ADD_MONTHS(TO_DATE('2014-10', 'yyyy-MM'), ROWNUM - 1),  
               'yyyyMM') as monthlist  
  FROM DUAL  
CONNECT BY ROWNUM <=  
           months_between(to_date('2015-06', 'yyyy-MM'),  
                          to_date('2014-10', 'yyyy-MM')) + 1  

获取周列表:   获取自然周    以周一开始  - 周日结束

SELECT trunc(to_DATE('2018-09-02', 'YYYY-MM-DD') + (ROWNUM - 1) * 7, 'iw') AS mon,
       trunc(to_DATE('2018-09-02', 'YYYY-MM-DD') + (ROWNUM - 1) * 7, 'iw') + 6 AS sun
  FROM DUAL
CONNECT BY ROWNUM <=
           (trunc(to_DATE('2018-10-31', 'YYYY-MM-DD'), 'iw') + 6 -
           trunc(to_DATE('2018-09-02', 'YYYY-MM-DD'), 'iw')) / 7 + 1

获取年份列表:

SELECT TO_CHAR(ADD_MONTHS(TO_DATE('2014-10', 'yyyy-MM'), (ROWNUM - 1) * 12),  
               'yyyy') as yearlist  
  FROM DUAL  
CONNECT BY ROWNUM <=  
           months_between(to_date('2015-06', 'yyyy-MM'),  
                          to_date('2014-10', 'yyyy-MM')) / 12 + 1  

 

分组统计,按照天、月份周和自然周、月、季度和年

https://blog.csdn.net/JavaAlpha/article/details/52277270


-- 按自然周的日期统计 
select to_char(next_day(t.CREATED+15/24 - 7,2),'YYYY-MM-DD') AS 周,sum(1) as 数量
from TB_EXT_TRADE t
WHERE
	t.TID LIKE 'SC%' OR t.TID LIKE 'WSC%'
group by to_char(next_day(t.CREATED+15/24 - 7,2),'YYYY-MM-DD')
ORDER BY 周;

分组统计周  自然周  select to_char(next_day(to_DATE('2018-09-02', 'YYYY-MM-DD') + 15 / 24 - 7, 2),'YYYY-MM-DD') from dual;   和  select trunc(to_DATE('2018-09-02', 'YYYY-MM-DD'),'iw') from dual;  取到的值 是一样的  获取该日期所在自然周的周一            自然周  以周一开始  周 日 结束

 

当前日期为当年第几周,几天,几月,几季度;ww,iw,w区别

http://blog.csdn.net/liuao107329/article/details/53516269 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值