oracle 有没有这样的日期函数计算出当前时间与某一时间的天数差,网上说oracle支持计算,但是发现oracle是按天数来算的,但如果时间是"2009-01-20 17:00:00",系统时间是“2009-1-19 19:00:00”,按理说时间差没有一天,可oracle自动计算时间后出来是一天
请问这样的怎么算,有这样的函数吗?

解决方案 »

  1.   

    Oracle计算时间差表达式 --获取两时间的相差豪秒数
    select ceil((To_date('2008-05-02 00:00:00' , 'yyyy-mm-dd hh24-mi-ss') - To_date('2008-04-30 23:59:59' , 'yyyy-mm-dd hh24-mi-ss')) * 24 * 60 * 60 * 1000) 相差豪秒数 FROM DUAL;
    /*
    相差豪秒数
    ----------
      86401000
    1 row selected
    */--获取两时间的相差秒数
    select ceil((To_date('2008-05-02 00:00:00' , 'yyyy-mm-dd hh24-mi-ss') - To_date('2008-04-30 23:59:59' , 'yyyy-mm-dd hh24-mi-ss')) * 24 * 60 * 60) 相差秒数 FROM DUAL;
    /*
    相差秒数
    ----------
         86401
    1 row selected
    */--获取两时间的相差分钟数
    select ceil(((To_date('2008-05-02 00:00:00' , 'yyyy-mm-dd hh24-mi-ss') - To_date('2008-04-30 23:59:59' , 'yyyy-mm-dd hh24-mi-ss'))) * 24 * 60)  相差分钟数 FROM DUAL;
    /*
    相差分钟数
    ----------
          1441
    1 row selected
    */--获取两时间的相差小时数
    select ceil((To_date('2008-05-02 00:00:00' , 'yyyy-mm-dd hh24-mi-ss') - To_date('2008-04-30 23:59:59' , 'yyyy-mm-dd hh24-mi-ss')) * 24)  相差小时数 FROM DUAL;
    /*
    相差小时数
    ----------
            25
    1 row selected
    */--获取两时间的相差天数
    select ceil((To_date('2008-05-02 00:00:00' , 'yyyy-mm-dd hh24-mi-ss') - To_date('2008-04-30 23:59:59' , 'yyyy-mm-dd hh24-mi-ss')))  相差天数 FROM DUAL;
    /*
    相差天数
    ----------
             2
    1 row selected
    */--获取两时间月份差
    select (EXTRACT(year FROM to_date('2009-05-01','yyyy-mm-dd')) - EXTRACT(year FROM to_date('2008-04-30','yyyy-mm-dd'))) * 12 + 
           EXTRACT(month FROM to_date('2008-05-01','yyyy-mm-dd')) - EXTRACT(month FROM to_date('2008-04-30','yyyy-mm-dd')) months
    from dual;
    /*
    MONTHS
    ----------
            13
    1 row selected
    */--获取两时间年份差
    select EXTRACT(year FROM to_date('2009-05-01','yyyy-mm-dd')) - EXTRACT(year FROM to_date('2008-04-30','yyyy-mm-dd')) years from dual;
    /*
    YEARS
    ----------
             1
    1 row selected
    */
      

  2.   

    不可能,为什么我的算出来是0.9.....
    SQL> select To_date('2009-01-20 17:00:00', 'yyyy-mm-dd hh24-mi-ss') -
      2              To_date('2009-1-19 19:00:00', 'yyyy-mm-dd hh24-mi-ss') df
      3    FROM DUAL;
     
            DF
    ----------
    0.91666666
     
    SQL>