• Oracle中的Round和Trunc


    一、Oracle中的Round和Trunc:

    如同对数字进行四舍五入和按位截取一样,Oracle对时间日期也提供了这两种功能。但比起对数字进行四舍五入和截取比较复杂:这是因为时间日期是有格式的。下面看看这两个函数的定义和用途:

    ROUND(date [, format])

    TRUNC(date [, format])

    Round函数对日期进行“四舍五入”,Trunc函数对日期进行截取。如果我们不指定格式的话,Round会返回一个最接近date参数的日期,而Trunc函数只会简单的截取时分秒部分,返回年月日部分。

    二、Round和Trunc函数示例:

    SQL >   select  to_char(sysdate,  ' yyyy-mm-dd hh24:mi:ss ' ) now_date,
      
    2              to_char( Round (sysdate), ' yyyy-mm-dd hh24:mi:ss '
    ) round_date,
      
    3              to_char(Trunc(sysdate), ' yyyy-mm-dd hh24:mi:ss '
    ) trunc_date
      
    4      from
     dual;

    NOW_DATE                               ROUND_DATE                             TRUNC_DATE
    -- ------------------------------------ -------------------------------------- ----------------------

    2008 - 06 - 30   14 : 52 : 13                      2008 - 07 - 01   00 : 00 : 00                      2008 - 06 - 30   00 : 00 : 00


    这是一个典型的例子,由于我们没有指定round和trunc函数的格式,所以Oracle默认采用了按日期时间的格式,该例子中当前的时间是下午 14:52分,已经超过了12:00 AM这个中界线,所以Round返回07-01日而非06-30日。而Trunc不管三七二十一直接截取前面日期部分返回。

    另外一个值得注意的地方是这两个函数返回的时分秒都是00:00:00,即一天的开始时间(对于12小时制的返回的是12:00:00 AM)。

    三、指定格式的Round和Trunc函数示例:

    如果我们对Round函数和Trunc函数指定了格式,事情就变得有点复杂了,不过核心思想还是不变:Round是四舍五入,Trunc是截取。举个例子来说,假如我们以年为格式,则现在Oracle的判断是基于年来判断,超过一年的一半(即6月30日),Round函数则返回下一年了,Trunc函数依然返回当前年。

    SQL >   select  sysdate "Now date",
      
    2              Round (sysdate,  ' yyyy '
    ) Round_year,
      
    3              Trunc(sysdate,  ' yyyy '
    ) Trunc_year
      
    4      from
     dual;

    Now date   ROUND_YEAR TRUNC_YEAR
    -- -------- ---------- ----------

    30 - 6月  - 08   01 - 1月  - 08   01 - 1月  - 08


    关于这两个函数可用的格式非常多,但日常应用中用得比较多的基本上就这几个,以Round函数为例:

    select   Round (sysdate,  ' Q ' ) Rnd_Q,
            
    Round (sysdate,  ' Month '
    ) Rnd_Month,
            
    Round (sysdate,  ' WW '
    ) Rnd_Week,
            
    Round (sysdate,  ' W '
    ) Rnd_Week_again,
            
    Round (sysdate,  ' DDD '
    ) Rnd_day,
            
    Round (sysdate,  ' DD '
    ) Rnd_day_again,
            
    Round (sysdate,  ' DAY '
    ) Rnd_day_of_week,
            
    Round (sysdate,  ' D '
    ) Rnd_day_of_week_again,
            
    Round (sysdate,  ' HH12 '
    ) Rnd_hour_12,
            
    Round (sysdate,  ' HH24 '
    ) Rnd_hour_24,
            
    Round (sysdate,  ' MI '
    ) Rnd_minute
      
    from  dual

    四、用trunc函数处理日期

     期用例 '2008-11-28 12:59:59'周五  

    1.没有fmt部分时

       语句: SELECT   TRUNC(TO_DATE('2008-11-28 12:00:01','YYYY-MM-DD hh24:mi:ss')) FROM   DUAL;
              结果: 2008-11-28  

            

    2.得到最当前日期之前的最近的一个周日的日期

       语句: SELECT   TRUNC(TO_DATE('2008-11-28 12:59:59','YYYY-MM-DD hh24:mi:ss'),'D') FROM   DUAL;   
       结果: 2008-11-23 周日

       语句: SELECT   TRUNC(TO_DATE('2008-11-28 12:59:59','YYYY-MM-DD hh24:mi:ss'),'D')+1 FROM   DUAL;   
       结果: 2008-11-24 周一

     

    3.得到最当前日期的所在月份的第一天

       语句: SELECT   TRUNC(TO_DATE('2008-11-28 12:59:59','YYYY-MM-DD hh24:mi:ss'),'MM') FROM   DUAL;   
       结果: 2008-11-1

       语句: SELECT   TRUNC(TO_DATE('2008-11-28 12:59:59','YYYY-MM-DD hh24:mi:ss'),'MM')-1 FROM   DUAL; 

       结果: 2008-10-31

     

    4.得到最当前日期的所在年份的第一天

       语句: SELECT   TRUNC(TO_DATE('2008-11-28 12:59:59','YYYY-MM-DD hh24:mi:ss'),'Y') FROM   DUAL;   
       结果: 2008-1-1

       语句: SELECT   TRUNC(TO_DATE('2008-11-28 12:59:59','YYYY-MM-DD hh24:mi:ss'),'Y')-1 FROM   DUAL; 

       结果: 2007-12-31

  • 相关阅读:
    一张图看懂开源许可协议,开源许可证GPL、BSD、MIT、Mozilla、Apache和LGPL的区别
    常用Flex 布局scss
    设置npm registry的几种方法
    JavaScript计算平方数的三种方法
    NPM 使用介绍
    x 的 y次幂科学计数法
    Docker 容器使用
    使用dos的tree命令输出文件夹树
    赣州(虔州)历史文化
    vue通过$ref获取不到元素样式?
  • 原文地址:https://www.cnblogs.com/xhk1228/p/3194877.html
Copyright © 2020-2023  润新知