<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:

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

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

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

    如果我們對(duì)Round函數(shù)和Trunc函數(shù)指定了格式,事情就變得有點(diǎn)復(fù)雜了,不過核心思想還是不變:Round是四舍五入,Trunc是截取。舉個(gè)例子來說,假如我們以年為格式,則現(xiàn)在Oracle的判斷是基于年來判斷,超過一年的一半(即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 閱讀(3760) 評(píng)論(0)  編輯  收藏 所屬分類: Oracle 開發(fā)
    <2008年6月>
    25262728293031
    1234567
    891011121314
    15161718192021
    22232425262728
    293012345

    常用鏈接

    留言簿(21)

    隨筆分類

    隨筆檔案

    BlogJava熱點(diǎn)博客

    好友博客

    搜索

    •  

    最新評(píng)論

    閱讀排行榜

    評(píng)論排行榜

    主站蜘蛛池模板: 三级网站免费观看| 巨胸喷奶水视频www免费视频| 日韩精品免费在线视频| 伊人久久亚洲综合| 人妻仑乱A级毛片免费看| 全部免费a级毛片| 十八禁的黄污污免费网站| 国产大片91精品免费观看男同| 亚洲综合国产成人丁香五月激情| 国产免费女女脚奴视频网| 亚洲人成综合在线播放| 国产在线观看麻豆91精品免费| 色偷偷亚洲女人天堂观看欧| 黄页网站免费在线观看| 亚洲人成自拍网站在线观看| 国产最新凸凹视频免费| gogo免费在线观看| 亚洲a一级免费视频| 91热成人精品国产免费| 中文字幕亚洲精品无码| 国产猛烈高潮尖叫视频免费| 国产精品偷伦视频免费观看了| 亚洲精品无码av人在线观看| 日韩精品在线免费观看| 亚洲人成在久久综合网站| 日本免费网站在线观看| 中文日本免费高清| 亚洲精品高清国产麻豆专区| 女人张腿给男人桶视频免费版 | 亚洲蜜芽在线精品一区| 最近免费中文字幕大全| 免费无码专区毛片高潮喷水| 亚洲AV日韩精品久久久久| 色se01短视频永久免费| 日本一区二区在线免费观看| 日韩精品一区二区亚洲AV观看| 成人免费看吃奶视频网站| 老司机精品免费视频| 亚洲av日韩av无码av| 区久久AAA片69亚洲| 99re热免费精品视频观看|