天天看點

Trunc 方法的詳解 , oracle

trunc函數作用是截取日期,能準确到整點。截取後得到的仍為date資料類型。

一、基本用法

1、預設截取到日,例如:

select trunc(sysdate) from dual;

結果:2015-06-24 00:00:00

2、截取年:

select trunc(sysdate,'YYYY') from dual;

結果:2015-01-01 00:00:00

3、截取月:

select trunc(sysdate,'MM') from dual;

結果:2015-06-01 00:00:00

4、截取日:

select trunc(sysdate,'DD') from dual;

結果:2015-06-24 00:00:00

5、截取小時:

select trunc(sysdate,'HH24') from dual;

結果:2015-06-24 10:00:00

6、截取分鐘:

select trunc(sysdate,'MI') from dual;

結果:2015-06-24 10:35:00

7、截取秒會報錯:

select trunc(sysdate,'SS') from dual;

直接使用sysdate。

二、加1的使用

1、加1表示加上一天:

select trunc(sysdate)+1 from dual;

結果:2015-06-25 00:00:00

2、加1小時:

select trunc(sysdate)+1/24 from dual;

結果:2015-06-24 01:00:00

3、加1分鐘:

select trunc(sysdate)+1/24/60 from dual;

結果:2015-06-24 00:01:00

4、加1秒鐘:

select trunc(sysdate)+1/24/60/60 from dual;

結果:2015-06-24 00:00:01

5、加10分鐘:

select trunc(sysdate)+1/24/60*10 from dual;

select trunc(sysdate)+10/(24*60) from dual;

補充:

【傳回】:日期

select sysdate from (www.111cn.net)dual --當時日期

select trunc(sysdate) from dual

select trunc(sysdate ,'DD') from dual --今天日期

select trunc(sysdate,'d')+7 from dual --本周星期日

select trunc(sysdate,'dy')+7 from dual --本周星期日

select trunc(sysdate,'day')+7 from dual --本周星期日

select trunc(sysdate,'q') from dual--本季開始日期

select trunc(sysdate,'month') from dual --本月開始日期

select trunc(sysdate ,'mm') from dual --本月開始日期

select trunc(sysdate,'year') from dual --本年開始日期

select trunc(sysdate ,'yyyy') from dual --本年開始日期

select trunc(sysdate ,'HH24') from dual --本小時開始時間

select trunc(sysdate ,'MI') from dual --本分鐘開始時間

select trunc(sysdate ,'CC') from dual --本世紀開始時間

select trunc(LAST_DAY(sysdate),'dd') from dual --本月最後一天

3、round(10.2356,2)函數可以對數字按指定保留小數位數四舍五入,這個函數還可以對日期四舍五入

select round(sysdate,'yyyy') from dual 四舍五入到年

select round(sysdate,'mm') from dual 四舍五入到月

select round(sysdate,'dd') from dual 四舍五入到日

select round(sysdate,'hh') from dual 四舍五入到小時

select round(sysdate,'mi') from dual 四舍五入到分鐘

4、TRUNC還可以對number類型使用,

TRUNC(89.985,2)=89.98

TRUNC(89.985)=89

TRUNC(89.985,-1)=80

from:http://www.111cn.net/database/Oracle/90044.htm

上一篇: TRUNC函數
下一篇: trunc方法