oracle 周 跨年,请教关于跨年日期查询的问题

最初由 mychary 发布

[B]提供个思路:

SQL> create table t (t date);

表已创建。

SQL> begin

2  for i in 1 .. 100 loop

3  insert into t values(sysdate -5*i);

4  end loop;

5  end ;

6  /

PL/SQL 过程已成功完成。

SQL> commit;

提交完成。

SQL> set pagesize 1000

SQL> alter session set nls_date_format='YYYYMMDD';

会话已更改。

SQL> select t from t;

T

--------

20070105

20061231

20061226

20061221

.....

20050912

20050907

20050902

20050828

已选择100行。

SQL> select a2-1||'年9月~'||a2||'年4月' no,num from

2  (

3  select to_char(round(t,'YYYY'),'YYYY') a2,count(*) num from t

4  where to_char(t,'MM') not in ('05','06','07','08')

5  group by to_char(round(t,'YYYY'),'YYYY')

6  );

NO                                                             NUM

------------------------------------------------------- ----------

2005年9月~2006年4月                                             49

2006年9月~2007年4月                                             26

SQL> spool off [/B]

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值