<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    posts - 262,  comments - 221,  trackbacks - 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


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

    常用鏈接

    留言簿(21)

    隨筆分類

    隨筆檔案

    BlogJava熱點博客

    好友博客

    搜索

    •  

    最新評論

    閱讀排行榜

    評論排行榜

    主站蜘蛛池模板: 免费国产怡红院在线观看| 91嫩草免费国产永久入口| 亚洲成a人片在线播放| 18未年禁止免费观看| 久久亚洲sm情趣捆绑调教| 日韩人妻无码精品久久免费一 | 亚洲欧好州第一的日产suv| 无限动漫网在线观看免费| 亚洲综合另类小说色区色噜噜| 亚洲AV成人无码网站| 国产乱子伦精品免费无码专区| 国产精品亚洲а∨无码播放麻豆 | 免费黄色大片网站| 国产天堂亚洲国产碰碰| 亚洲高清无码专区视频| 99在线视频免费观看| 亚洲黄色三级视频| 免费毛片在线看片免费丝瓜视频 | 四虎永久成人免费| 午夜成人无码福利免费视频| 在线亚洲97se亚洲综合在线 | 亚洲自偷精品视频自拍| 免费在线观看的网站| 国产亚洲精品2021自在线| 伊人久久大香线蕉亚洲| 最近中文字幕大全免费视频 | 亚洲色无码专区一区| 亚洲国产成人精品无码久久久久久综合 | 亚洲第一极品精品无码久久| 久草视频免费在线| 特级一级毛片免费看| 亚洲精品国产成人99久久| 成人性生免费视频| 国产99久久久国产精免费| 亚洲视频免费观看| 免费一级特黄特色大片在线观看| 久久免费国产精品一区二区| 亚洲制服丝袜在线播放| 亚洲精品无码成人片在线观看 | 一级特黄aa毛片免费观看| 精品国产日韩久久亚洲|