test 表里有两个varchar类型的字段,算他们之间相隔的时间(精确到分钟)。
           first_time                          second_time
        2009-10-09 16:17:02                 2009-10-09 16:24:47
用select to_date(second_time,'YYYY-MM-DD HH24:MI:SS')-to_date(first_time,'YYYY-MM-DD HH24:MI:SS'))*1440 as time from test where 1=1; 
得到time = 7.75我想使结果得到7。该怎么修改。
谢谢。

解决方案 »

  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.   

    7.75-->7
    加个trunc函数就行了
      

  3.   

    select floor(7.75) from dual;