To_Date函数用法      

select * from emp
    where dates 
    between
    to_date('2007-06-12 10:00:00', 'yyyy-mm-dd hh24:mi:ss')
    and
    to_date('2007-06-12 10:00:00', 'yyyy-mm-dd hh24:mi:ss')

        当省略HH、MI和SS对应的输入参数时,Oracle使用0作为DEFAULT值。如果输入的日期数据忽略时间部分,Oracle会将时、分、秒部分都置为0,也就是说会取整到日。

        同样,忽略了DD参数,Oracle会采用1作为日的默认值,也就是说会取整到月。

        但是,不要被这种“惯性”所迷惑,如果忽略MM参数,Oracle并不会取整到年,取整到当前月。

      注意:

       1.在使用Oracle的to_date函数来做日期转换时,可能会直觉地采用“yyyy-MM-dd HH:mm:ss”的格式作为格式进行转换,但是在Oracle中会引起错误:“ORA 01810 格式代码出现两次”。如:

select to_date('2005-01-01 13:14:20','yyyy-MM-dd HH24:mm:ss') from dual;


原因是SQL中不区分大小写,MM和mm被认为是相同的格式代码,所以Oracle的SQL采用了mi代替分钟。select to_date('2005-01-01 13:14:20','yyyy-MM-dd HH24:mi:ss') from dual;
       2.另要以24小时的形式显示出来要用HH24

select to_char(sysdate,'yyyy-MM-dd HH24:mi:ss') from dual;//mi是分钟
select to_char(sysdate,'yyyy-MM-dd HH24:mm:ss') from dual;//mm会显示月份

Oracle中几个关于日期方面的SQL实例

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

  SQL>   select   sysdate,to_char(sysdate,'D')   from   dual;   
    
  SYSDATE       T   
  ---------   -   
  27-MAR-03   5  

类似:

  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;       --日   


  ddd   年中的第几天   
  WW   年中的第几个星期   
  W   该月中第几个星期   
  D   周中的星期几   
  hh   小时(12)   
  hh24   小时(24)   
  Mi   分   
  ss   秒

取当前日期是星期几中文显示:

SQL>   select   to_char(sysdate,'day')   from   dual;   
    
  TO_CHAR(SYSDATE,'DAY')   
  ----------------------   
  星期四  


4:得到当前的日期

select sysdate from dual;

5:得到当天凌晨0点0分0秒的日期

select trunc(sysdate) from dual;

-- 得到这天的最后一秒

select trunc(sysdate) + 0.99999 from dual;

-- 得到小时的具体数值

select trunc(sysdate) + 1/24 from dual;

select trunc(sysdate) + 7/24 from dual;

6:得到明天凌晨0点0分0秒的日期

select trunc(sysdate+1) from dual;

select trunc(sysdate)+1 from dual;


7: 本月一日的日期

select trunc(sysdate,'mm') from dual;


8:得到下月一日的日期

select trunc(add_months(sysdate,1),'mm') from dual;

9:返回当前月的最后一天

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;


10:得到一年的每一天

select trunc(sysdate,'yyyy')+ rn -1 date0 
from 
(select rownum rn from all_objects 
where rownum<366);

11:今天是今年的第N天

SELECT TO_CHAR(SYSDATE,'DDD') FROM DUAL;

12:如何在给现有的日期加上2年

select add_months(sysdate,24) from dual;

13:判断某一日子所在年分是否为润年 

select decode(to_char(last_day(trunc(sysdate,'y')+31),'dd'),'29','闰年','平年') from dual;

14:判断两年后是否为润年

select decode(to_char(last_day(trunc(add_months(sysdate,24),'y')+31),'dd'),'29','闰年','平年') from dual;

15:得到日期的季度

select ceil(to_number(to_char(sysdate,'mm'))/3) from dual;

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

Logo

华为开发者空间,是为全球开发者打造的专属开发空间,汇聚了华为优质开发资源及工具,致力于让每一位开发者拥有一台云主机,基于华为根生态开发、创新。

更多推荐