posts - 262,  comments - 221,  trackbacks - 0
          一、Oracle中的Round和Trunc:

          如同對(duì)數(shù)字進(jìn)行四舍五入和按位截取一樣,Oracle對(duì)時(shí)間日期也提供了這兩種功能。但比起對(duì)數(shù)字進(jìn)行四舍五入和截取比較復(fù)雜:這是因?yàn)闀r(shí)間日期是有格式的。下面看看這兩個(gè)函數(shù)的定義和用途:

          ROUND(date [, format])

          TRUNC(date [, format])

          Round函數(shù)對(duì)日期進(jìn)行“四舍五入”,Trunc函數(shù)對(duì)日期進(jìn)行截取。如果我們不指定格式的話,Round會(huì)返回一個(gè)最接近date參數(shù)的日期,而Trunc函數(shù)只會(huì)簡(jiǎn)單的截取時(shí)分秒部分,返回年月日部分。

          二、Round和Trunc函數(shù)示例:
          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

          這是一個(gè)典型的例子,由于我們沒(méi)有指定round和trunc函數(shù)的格式,所以O(shè)racle默認(rèn)采用了按日期時(shí)間的格式,該例子中當(dāng)前的時(shí)間是下午14:52分,已經(jīng)超過(guò)了12:00 AM這個(gè)中界線,所以Round返回07-01日而非06-30日。而Trunc不管三七二十一直接截取前面日期部分返回。

          另外一個(gè)值得注意的地方是這兩個(gè)函數(shù)返回的時(shí)分秒都是00:00:00,即一天的開(kāi)始時(shí)間(對(duì)于12小時(shí)制的返回的是12:00:00 AM)。

          三、指定格式的Round和Trunc函數(shù)示例:

          如果我們對(duì)Round函數(shù)和Trunc函數(shù)指定了格式,事情就變得有點(diǎn)復(fù)雜了,不過(guò)核心思想還是不變:Round是四舍五入,Trunc是截取。舉個(gè)例子來(lái)說(shuō),假如我們以年為格式,則現(xiàn)在Oracle的判斷是基于年來(lái)判斷,超過(guò)一年的一半(即6月30日),Round函數(shù)則返回下一年了,Trunc函數(shù)依然返回當(dāng)前年。
          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

          關(guān)于這兩個(gè)函數(shù)可用的格式非常多,但日常應(yīng)用中用得比較多的基本上就這幾個(gè),以Round函數(shù)為例:
          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


          -------------------------------------------------------------
          生活就像打牌,不是要抓一手好牌,而是要盡力打好一手爛牌。
          posted on 2008-06-30 14:47 Paul Lin 閱讀(3765) 評(píng)論(0)  編輯  收藏 所屬分類: Oracle 開(kāi)發(fā)
          <2008年6月>
          25262728293031
          1234567
          891011121314
          15161718192021
          22232425262728
          293012345

          常用鏈接

          留言簿(21)

          隨筆分類

          隨筆檔案

          BlogJava熱點(diǎn)博客

          好友博客

          搜索

          •  

          最新評(píng)論

          閱讀排行榜

          評(píng)論排行榜

          主站蜘蛛池模板: 教育| 岐山县| 新昌县| 贵德县| 大关县| 洪湖市| 盱眙县| 城市| 永宁县| 乌拉特前旗| 太和县| 新泰市| 桂林市| 江山市| 尉犁县| 库车县| 纳雍县| 九寨沟县| 阳山县| 海伦市| 灵丘县| 汉中市| 本溪市| 石嘴山市| 泰兴市| 资兴市| 神木县| 克什克腾旗| 龙州县| 汉阴县| 新余市| 信宜市| 玛多县| 苏尼特左旗| 郓城县| 贞丰县| 贵德县| 贡嘎县| 都江堰市| 昭通市| 荣昌县|