CONAN ZONE

          你越掙扎我就越興奮

          BlogJava 首頁 新隨筆 聯系 聚合 管理
            0 Posts :: 282 Stories :: 0 Comments :: 0 Trackbacks
          一、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
          posted on 2008-07-02 20:33 CONAN 閱讀(639) 評論(0)  編輯  收藏 所屬分類: Oracle
          主站蜘蛛池模板: 南靖县| 通渭县| 宜良县| 昭通市| 福安市| 灵寿县| 黄石市| 武鸣县| 平乡县| 栖霞市| 招远市| 佛冈县| 仪陇县| 合山市| 确山县| 益阳市| 淮滨县| 兴宁市| 资兴市| 咸丰县| 万载县| 常州市| 富蕴县| 恩施市| 天台县| 贡觉县| 嘉定区| 安顺市| 开化县| 香格里拉县| 日土县| 双辽市| 防城港市| 通河县| 临沂市| 柳江县| 平果县| 陵水| 迁西县| 甘孜| 米林县|