oracle获得每周,每月,每季度,每年的第一天

来源:互联网 发布:java中如何实现多态 编辑:程序博客网 时间:2024/04/27 19:13

1.获取当前年月日

trunc(sysdate) 或者 trunc(sysdate,'dd')

2.当年第一天

trunc(sysdate,'yyyy')

3.当月第一天

trunc(sysdate,'mm')

4.当周第一天

trunc(sysdate,'d')

5.当前季度第一天,下一季度第一天

trunc(sysdate,'q'), trunc(add_months(sysdate,3),'q')

6.每半年的第一天

add_months(trunc(sysdate,'yyyy'),6)

7.当月天数

extract(day from last_day(sysdate))

8.当年天数

trunc(add_months(sysdate,12),'yyyy')-trunc(sysdate,'yyyy')

9.获取当月的每一天的日期值

select trunc(sysdate,'mm')+rownum-1 from dual

connect  by rownum<=last_day(sysdate)-trunc(sysdate,'mm')+1

10.获取当年的每一天的值

select trunc(sysdate,'yyyy')+rownum-1 from dual

connect by rownum<=

trunc(add_months(sysdate,12),'yyyy')-trunc(sysdate,'yyyy')

11.获取指定日期到当天的所有日期值

select to_date('2012-3-3','yyyy-mm-dd')+rownum-1 from dual

connect by rownum<=trunc(sysdate)-to_date('2012-3-3','yyyy-mm-dd')+1

12 下周几的值

next_day(sysdate,'星期一') next_day(sysdate,'Monday')  //根据自己的数据库设定输入汉字或英文