1. 程式人生 > >Oracle時間型別總結

Oracle時間型別總結

1.DATE資料型別

     這個資料型別我們實在是太熟悉了,當我們需要表示日期和時間的話都會想到date型別。它可以儲存月,年,日,世紀,時,分和秒。它典型地用來表示什麼時候事情已經發生或將要發生。
     DATE資料型別的問題在於它表示兩個事件發生時間間隔的度量粒度是秒。這個問題將在稍後討論timestamp的時候被解決。可以使用TO_CHAR函式把DATE資料進行傳統地包裝,達到表示成多種格式的目的。

1 SQL> SELECT TO_CHAR(date1,'MM/DD/YYYY HH24:MI:SS') "Date" FROM
date_table; 2 3 Date 4 --------------------------- 5 06/20/2003 16:55:14 6 06/26/2003 11:16:36

   大多數人陷入的麻煩就是計算兩個時間間的間隔年數、月數、天數、小時數和秒數。你需要明白的是,當你進行兩個日期的相減運算的時候,得到的是天數。你需要乘上每天的秒數(1天=86400秒),然後,你可以再次計算得到你想要的間隔數。下面就是我的解決方法,可以精確計算出兩個時間的間隔。我明白這個例子可以更簡短些,但是我是為了顯示所有的數字來強調計算方式。

複製程式碼
 1 SELECT
TO_CHAR(date1, 'MMDDYYYY:HH24:MI:SS') date1, 2 TO_CHAR(date2, 'MMDDYYYY:HH24:MI:SS') date2, 3 trunc(86400 * (date2 - date1)) - 4 60 * (trunc((86400 * (date2 - date1)) / 60)) seconds, 5 trunc((86400 * (date2 - date1)) / 60) - 6 60 * (trunc(((86400 * (date2 - date1)) / 60) / 60)) minutes, 7
trunc(((86400 * (date2 - date1)) / 60) / 60) - 8 24 * (trunc((((86400 * (date2 - date1)) / 60) / 60) / 24)) hours, 9 trunc((((86400 * (date2 - date1)) / 60) / 60) / 24) days, 10 trunc(((((86400 * (date2 - date1)) / 60) / 60) / 24) / 7) weeks 11 FROM date_table 12 13 DATE1 DATE2 SECONDS MINUTES HOURS DAYS WEEKS 14 ----------------- ----------------- ---------- ---------- ---------- ---------- ---------- 15 06202003:16:55:14 07082003:11:22:57 43 27 18 17 2 16 06262003:11:16:36 07082003:11:22:57 21 6 0 12 1
複製程式碼

2.TIMESTAMP 資料型別

    DATE資料型別的主要問題是它粒度不能足夠區別出兩個事件哪個先發生。ORACLE已經在DATE資料型別上擴展出來了TIMESTAMP資料型別,它包括了所有DATE資料型別的年月日時分秒的資訊,而且包括了小數秒的資訊。如果你想把   DATE型別轉換成TIMESTAMP型別,就使用CAST函式。

1 SQL> SELECT CAST(date1 AS TIMESTAMP) "Date" FROM t; 
2 Date 
3 ----------------------------------------------------- 
4 20-JUN-03 04.55.14.000000 PM 
5 26-JUN-03 11.16.36.000000 AM

     正如你看到的,在轉換後的時間段尾部有了一段“.000000”。這是因為從date轉換過來的時候,沒有小數秒的資訊,預設為0。而且顯示格式是按照引數NLS_TIMESTAMP_FORMAT定的預設格式顯示。當你把一個表中date型別欄位的資料移到另一個表的timestamp型別欄位中去的時候,可以直接寫INSERT SELECT語句,oracle會自動為你做轉換的。

1 SELECT TO_CHAR(time1,'MM/DD/YYYY HH24:MI:SS') "Date" FROM date_table 
2 Date 
3 ------------------- 
4 06/20/2003 16:55:14 
5 06/26/2003 11:16:36

    TIMESTAMP資料的格式化顯示和DATE 資料一樣。注意,to_char函式支援date和timestamp,但是trunc卻不支援TIMESTAMP資料型別。這已經清楚表明了在當兩個時間的差別極度重要的情況下,使用TIMESTAMP資料型別要比DATE資料型別更確切。

1 SELECT TO_CHAR(time1,'MM/DD/YYYY HH24:MI:SS:FF3') "Date" FROM date_table
2 
3 Date 
4 ----------------------- 
5 06/20/2003 16:55:14:000 
6 06/26/2003 11:16:36:000

     計算timestamp間的資料差別要比老的date資料型別更容易。當你直接相減的話,看看會發生什麼。結果將更容易理解,第一行的17天,18小時,27分鐘和43秒。

複製程式碼
 1 SELECT time1,
 2        time2,
 3        substr((time2 - time1), instr((time2 - time1), ' ') + 7, 2) seconds,
 4        substr((time2 - time1), instr((time2 - time1), ' ') + 4, 2) minutes,
 5        substr((time2 - time1), instr((time2 - time1), ' ') + 1, 2) hours,
 6        trunc(to_number(substr((time2 - time1), 1, instr(time2 - time1, ' ')))) days,
 7        trunc(to_number(substr((time2 - time1), 1, instr(time2 - time1, ' '))) / 7) weeks
 8   FROM date_table
 9   
10 TIME1 TIME2 SECONDS MINUTES HOURS DAYS WEEKS 
11 ------------------------- -------------------------- ------- ------- ----- ---- ----- 
12 06/20/2003:16:55:14:000000 07/08/2003:11:22:57:000000 43 27 18 17 2 
13 06/26/2003:11:16:36:000000 07/08/2003:11:22:57:000000 21 06 00 12 1 
複製程式碼

     這就意味著不再需要關心一天有多少秒在麻煩的計算中。因此,得到天數、月數、天數、時數、分鐘數和秒數就成為用substr函式摘取出數字的事情了。


3.系統日期和時間

     為了得到系統時間,返回成date資料型別。你可以使用sysdate函式。

1 SQL> SELECT SYSDATE FROM DUAL;

     為了得到系統時間,返回成timestamp資料型別。你可以使用systimpstamp函式。

1 SQL> SELECT SYSTIMESTAMP FROM DUAL;

     你可以設定初始化引數FIXED_DATE指定sysdate函式返回一個固定值。這用在測試日期和時間敏感的程式碼。注意,這個引數對於systimestamp函式無效。

複製程式碼
 1 SQL> ALTER SYSTEM SET fixed_date = '2003-01-01-10:00:00'; 
 2 System altered.
 3 
 4 SQL> select sysdate from dual; 
 5 SYSDATE 
 6 --------- 
 7 01-JAN-03
 8 
 9 SQL> select systimestamp from dual; 
10 SYSTIMESTAMP 
11 --------------------------------------------------------- 
12 09-JUL-03 11.05.02.519000 AM -06:00
複製程式碼

4.date和timestamp 的區別

     date型別是Oracle常用的日期型變數,他的時間間隔是秒。兩個日期型相減得到是兩個時間的間隔,注意單位是“天”。例如:檢視一下當前距離倫敦奧運會開幕還有多長時間:

1 select to_date('2012-7-28 03:12:00','yyyy-mm-dd hh24:mi:ss')-sysdate from dual

結果是:92.2472685185185天,然後你根據相應的時間換算你想要的間隔就行!這個結果可能對程式設計師有用,對於想直接看到結果的人,這個數字還不是很直觀,所以,就引出了timestamp型別

timestamp是DATE型別的擴充套件,可以精確到小數秒(fractional_seconds_precision),可以是0 to9,預設是6。兩個timestamp相減的話,不能直接的得到天數書,而是得到,
多少天,多少小時,多少秒等,例如:同樣檢視一下當前距離倫敦奧運會開幕還有多長時間.

1 select to_timestamp('2012-7-28 03:12:00','yyyy-mm-dd hh24:mi:ss')-systimestamp from dual

     結果是:+000000092 05:51:24.032000000,稍加擷取,就可以得到92天5小時,51分鐘,24秒,這樣使用者看起來比較直觀一些!但是這個數字對程式設計師來說不是很直觀了,如果想要具體的時間長度的話,並且精度不要求到毫秒的話,可以將timestamp型別轉成date型別,然後直接相減即可。


5.date和timestamp之間的相互轉換可以通過

to_char來轉換timestamp——>date:

1 select to_date(to_char(systimestamp,'yyyy-mm-dd hh24:mi:ss'),'yyyy-mm-dd hh24:mi:ss') from dual

date ——>timestamp:

1 select to_timestamp(to_char(sysdate,'yyyy-mm-dd hh24:mi:ss'),'yyyy-mm-dd hh24:mi:ss') from dual

     當使用date和timestamp型別的時候,選擇是很清楚的。你可以隨意處置date和timestamp型別。當你試圖轉換到更強大的timestamp的時候,需要注意,它們既有類似的地方,更有不同的地方,而足以造成破壞。兩者在簡潔和間隔尺寸方面各有優勢,請合理地選擇。