ASP源码.NET源码PHP源码JSP源码JAVA源码DELPHI源码PB源码VC源码VB源码Android源码
当前位置:首页 >> 数据库 >> Oracle >> ORACLE 取季度之间,时间区间查询,季度,月份,星期等时间信息

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

来源:网络整理     时间:2015-04-11     关键词:

本篇文章主要介绍了"ORACLE 取季度之间,时间区间查询,季度,月份,星期等时间信息",主要涉及到方面的内容,对于Oracle感兴趣的同学可以参考一下: --本季度第一天select to_char(trunc(sysdate, 'q'), 'yyyy-mm-dd') from dual;--上个季度最后一天(可...

--本季度第一天
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');--按照每季度进行统计

以上就介绍了ORACLE 取季度之间,时间区间查询,季度,月份,星期等时间信息,包括了方面的内容,希望对Oracle有兴趣的朋友有所帮助。

本文网址链接:http://www.codes51.com/article/detail_125948.html

相关图片

相关文章