一、
Oracle
中的
Round
和Trunc:
如同对数字进行四舍五入和按位截取一样,
Oracle
对时间日期也提供了这两种功能。但比起对数字进行四舍五入和截取比较复杂:这是因为时间日期是有格式的。下面看看这两个函数的定义和用途:
ROUND
(date [, format])
TRUNC(date [, format])
Round
函数对日期进行“四舍五入”,Trunc函数对日期进行截取。如果我们不指定格式的话,
Round
会返回一个最接近date参数的日期,而Trunc函数只会简单的截取时分秒部分,返回年月日部分。
二、
Round
和Trunc函数示例:
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函数依然返回当前年。
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
函数为例:
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
四、用trunc函数处理日期
日 期用例 '2008-11-28 12:59:59'周五
1.没有fmt部分时
语句:
SELECT TRUNC(TO_DATE('2008-11-28 12:00:01','YYYY-MM-DD hh24:mi:ss')) FROM DUAL;
结果:
2008-11-28
2.得到最当前日期之前的最近的一个周日的日期
语句:
SELECT TRUNC(TO_DATE('2008-11-28 12:59:59','YYYY-MM-DD hh24:mi:ss'),
'D')
FROM DUAL;
结果:
2008-11-23 周日
语句:
SELECT
TRUNC(TO_DATE('2008-11-28 12:59:59','YYYY-MM-DD hh24:mi:ss'),
'D')+1
FROM DUAL;
结果:
2008-11-24 周一
3.得到最当前日期的所在月份的第一天
语句: SELECT TRUNC(TO_DATE('2008-11-28 12:59:59','YYYY-MM-DD hh24:mi:ss'),
'MM')
FROM DUAL;
结果:
2008-11-1
语句: SELECT TRUNC(TO_DATE('2008-11-28 12:59:59','YYYY-MM-DD hh24:mi:ss'), 'MM')-1 FROM DUAL;
结果: 2008-10-31
4.得到最当前日期的所在年份的第一天
语句: SELECT TRUNC(TO_DATE('2008-11-28 12:59:59','YYYY-MM-DD hh24:mi:ss'),
'Y')
FROM DUAL;
结果:
2008-1-1
语句: SELECT TRUNC(TO_DATE('2008-11-28 12:59:59','YYYY-MM-DD hh24:mi:ss'), 'Y')-1 FROM DUAL;
结果: 2007-12-31