ORACLE 取季度之间,时间区间查询,季度,月份,星期等时间信息

--本季度第一天
select to_char(trunc(sysdate, 'q'), 'yyyy-mm-dd') from dual;

--上个季度最后一天(可以用本季度第一天减去1得到)
select to_char(trunc(sysdate, 'q') - 1, 'yyyy-mm-dd') from dual;

--上个季度第一天(本季度第一天 减 3个月)
select to_char(add_months(trunc(sysdate, 'q'), -3), 'yyyy-mm-dd')  from dual;

--上个季度第一天(本季度减一个月之后的月份的最后一天)
select to_char(last_day(add_months(trunc(sysdate, 'q'), -1)), 'yyyy-mm-dd')  from dual
  
--取得当前日期是本月的第几周  
select to_char(sysdate,'yyyymmdd    w    hh24:mi:ss')   from   dual; 

select to_char(sysdate, 'w') from dual;

--取得当前日期是一个星期中的第几天,注意星期日是第一天

select sysdate, to_char(sysdate, 'd') from dual;
--类似:
select to_char(sysdate, 'yyyy') from dual; --当前年 
select to_char(sysdate, 'q' ) from dual; --当前季度
select to_char(sysdate, 'mm') from dual; --当前月 
select to_char(sysdate, 'dd') from dual; --当前日

--取当前日期是星期几的中文显示:
select   to_char(sysdate, 'day')   from   dual; 

--如果一个表在一个date类型的字段上面建立了索引,如何使用
alter session set nls_date_format='yyyy-mm-dd hh24:mi:ss'

--得到当前的日期
select sysdate from dual;

--得到当天凌晨0点0分0秒的日期
select to_char(trunc(sysdate), 'yyyymmdd hh:mi:ss' ) from dual;

--得到这天的最后一秒
select trunc(sysdate) + 0.99999 from dual;

--得到小时的具体数值
select trunc(sysdate) + 1 / 24 from dual;
select trunc(sysdate) + 7 / 24 from dual;

--得到明天凌晨0点0分0秒的日期
select trunc(sysdate + 1) from dual;
select trunc(sysdate) + 1 from dual;


--本月一日的日期
select trunc(sysdate, 'mm') from dual;


--得到下月一日的日期
select add_months(trunc(sysdate, 'mm'), 1) from dual;
select trunc(add_months(sysdate, 1), 'mm') from dual;

--返回当前月的最后一天?
select last_day(sysdate) from dual;
select last_day(trunc(sysdate)) from dual;
select trunc(last_day(sysdate)) from dual;
select trunc(add_months(sysdate, 1), 'mm') - 1 from dual;

--得到一年的第一天 
select trunc(sysdate, 'y') from dual

--得到一年的每一天 
select trunc(sysdate, 'yyyy') + rn - 1 date0
  from (select rownum rn from all_objects where rownum < 366) t;

--今天是今年的第n天
select to_char(sysdate, 'ddd') from dual;

--如何在给现有的日期加上2年
select add_months(sysdate, 24) from dual;

--判断某一日子所在年分是否为润年
select last_day(trunc(sysdate, 'yyyy') + 31) from dual   --通过一年的第一天加上31天到2月,然后取2月最后一天
select decode(to_char(last_day(trunc(sysdate, 'y') + 31), 'dd'),
              '29',
              '闰年',
              '平年')
  from dual;

--判断两年后是否为润年
select decode(to_char(last_day(trunc(add_months(sysdate, 24), 'y') + 31), 'dd'),
              '29',
              '闰年',
              '平年')
  from dual;

--得到日期的季度
select trunc(sysdate, 'mi') from dual ;
select to_number(to_char(sysdate,'mm')) from dual;
select ceil(to_number(to_char(sysdate,'mm'))/3) from dual;
select to_char(sysdate, 'q') from dual;

--本周的第一天和最后一天,考虑到中国人习惯是周一为每周的第一天(国际惯例是周日为第一天,oracle也是这样)
select trunc(sysdate,'d')+1,trunc(sysdate,'d')+7 from dual where to_char(sysdate,'day')<>'星期日'
union all
select trunc(sysdate,'d')+1-7,trunc(sysdate,'d')+7-7 from dual where to_char(sysdate,'day')='星期日'

--当前季度的第一天
select to_char(trunc(sysdate,'q'),'yyyy-mm-dd') from dual;
--当前季度的最后一天
select to_char(add_months(trunc(sysdate, 'q'), +3)-1, 'yyyy-mm-dd')
  from dual;

select to_char(trunc(add_months(last_day(sysdate), -1) + 1), 'yyyy-mm-dd') "本月第一天",
       to_char(last_day(sysdate), 'yyyy-mm-dd') "本月最后一天" from dual;

select to_char(last_day(sysdate), 'dd') from dual--返回某个月的最后一天
select to_char(sysdate,'q') from dual;--指定日期的季度
select to_char(sysdate,'mm') from dual;--月份
select to_char(sysdate,'ww') from dual;--当年第几周
select to_char(sysdate,'w') from dual ;--本月第几周
select to_char(sysdate,'dd') from dual;--当月第几天
select to_char(sysdate,'d') from dual;--周内第几天
select to_char(sysdate,'dy') from dual;--星期几
select last_day(sysdate) from dual;--本月最后一天
select add_months(sysdate,2) from dual;--当前日期d后推n个月 
select months_between(sysdate,to_date('2012-11-12','yyyy-mm-dd'))from dual;--日期f和s间相差月数
select (next_day(sysdate,1)+1) from dual;--指定的日期之后的第一个工作日的日期
select to_char(add_months(last_day(sysdate),-1),'yyyy-mm-dd') lastday from dual;--上月末天
select to_char(add_months(sysdate,-1),'yyyy-mm-dd') pretoday from dual;--上月今天
select to_char(add_months(last_day(sysdate)+1,-2),'yyyy-mm-dd') firstday from dual;--上月第一天
select to_char(sysdate,'ww') from dual group by to_char(sysdate,'ww');--按照每周进行统计
select to_char(sysdate,'mm') from dual group by to_char(sysdate,'mm');--按照每月进行统计
select to_char(sysdate,'q') from dual group by to_char(sysdate,'q');--按照每季度进行统计
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值