Contents ...
udn網路城邦
oracle 四捨五入函數_1
2009/02/16 21:43
瀏覽4,633
迴響0
推薦2
引用0

如何使用 Oracle Round 函數 ( 四捨五入 )

描述 : 傳回一個數值,該數值是按照指定的小數位元數進行四捨五入運算的結果。

SELECT ROUND( number, [ decimal_places ] ) FROM DUAL

參數 :

number : 欲處理之數值

decimal_places : 四捨五入 , 小數取幾位 ( 預設為 0 )

Sample :

select round(123.456) from dual; 回傳 123

select round(123.456, 0) from dual; 回傳 123

select round(123.456, 1) from dual; 回傳 123.5

select round(123.456, 2) from dual; 回傳 123.46

select round(123.456, 3) from dual; 回傳 123.456

select round(-123.456, 2) from dual; 回傳 -123.46

一、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
ceil(number)   大於或等於的最小整數
floor(number)   小於或等於的最大整數
trunc(number,m)   在整數number的m位置截掉m及以後的位數:
round(number,m)   用法同trunc,採用四捨五入的方式.

如:
ceil(17.3)=18
floor(12.36)=12

trunc(15.78,1)=15.7
trunc(15.78,-1)=15
trunc(15.78,-1)=10

round(14.75,1)=14.8
round(14.75,0)=15
有誰推薦more
全站分類:心情隨筆 心情日記
自訂分類:DBMS
發表迴響

會員登入