Oracle中的Round和Trunc:

系统 1565 0

一、 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

Oracle中的Round和Trunc:


更多文章、技术交流、商务合作、联系博主

微信扫码或搜索:z360901061

微信扫一扫加我为好友

QQ号联系: 360901061

您的支持是博主写作最大的动力,如果您喜欢我的文章,感觉我的文章对您有帮助,请用微信扫描下面二维码支持博主2元、5元、10元、20元等您想捐的金额吧,狠狠点击下面给点支持吧,站长非常感激您!手机微信长按不能支付解决办法:请将微信支付二维码保存到相册,切换到微信,然后点击微信右上角扫一扫功能,选择支付二维码完成支付。

【本文对您有帮助就好】

您的支持是博主写作最大的动力,如果您喜欢我的文章,感觉我的文章对您有帮助,请用微信扫描上面二维码支持博主2元、5元、10元、自定义金额等您想捐的金额吧,站长会非常 感谢您的哦!!!

发表我的评论
最新评论 总共0条评论