Oracle中TIMESTAMP的幾種類型介紹與實例
TIMESTAMP的幾種類型比較
TIMESTAMP
時間戳類型,與date的區(qū)別在于,date不能精確到毫秒,而timestamp可以精確到毫秒,毫秒的位數為0-9位,默認為6位。
SQL> select tp from timestamp_test; TP -------------------------------------------------------------------------------- 01-3月 -16 09.22.33.000000 上午
TIMESTAMP WITH TIME ZONE
TIMESTAMP WITH TIME ZONE 與 TIMESTAMP的區(qū)別在于,前者輸出顯示攜帶存入該時間值的數據庫時區(qū),后者輸出不攜帶時區(qū)。
SQL> select tp_tz from timestamp_test; TP_TZ -------------------------------------------------------------------------------- 01-3月 -16 09.22.33.000000 上午 +08:00
TIMESTAMP WITH LOCAL TIME ZONE與TIMESTAMP的區(qū)別在于,前者的輸出受時區(qū)影響,會跟著時區(qū)的變化而變化,而后者存入數據庫后將不受時區(qū)影響。即前者以數據庫本地時區(qū)保存數據,輸出時將轉換成客戶端時區(qū)輸出。
SQL> select tp_l_tz from timestamp_test; TP_L_TZ -------------------------------------------------------------------------------- 01-3月 -16 09.22.33.000000 上午
實戰(zhàn)演練
# 創(chuàng)建timestamp_test測試表 SQL> create table timestamp_test(dt date,tp timestamp(6),tp_tz timestamp(6) with time zone,tp_l_tz timestamp(6) with local time zone); Table created # 在測試表中添加數據 SQL> insert into timestamp_test values(sysdate,sysdate,sysdate,sysdate); 1 row inserted SQL> commit; Commit complete # 查看數據庫的時區(qū)和當前會話的時區(qū) SQL> select dbtimezone,sessiontimezone from dual; DBTIMEZONE SESSIONTIMEZONE ---------- --------------------------------------------------------------------------- +00:00 +08:00 # 查看當前時間 SQL> select sysdate from dual; SYSDATE ----------- 2016/3/1 9: # 查看測試表的數據 SQL> select * from timestamp_test; DT TP TP_TZ TP_L_TZ ----------- -------------------------------------------------------------------------------- -------------------------------------------------------------------------------- -------------------------------------------------------------------------------- 2016/3/1 9: 01-3月 -16 09.22.33.000000 上午 01-3月 -16 09.22.33.000000 上午 +08:00 01-3月 -16 09.22.33.000000 上午 # 修改當前會話的時區(qū) SQL> alter session set time_zone='+10:00'; Session altered # 查看當前會話時區(qū)修改后的測試表的數據 SQL> select dbtimezone,sessiontimezone from dual; DBTIMEZONE SESSIONTIMEZONE ---------- --------------------------------------------------------------------------- +00:00 +10:00 SQL> select * from timestamp_test; DT TP TP_TZ TP_L_TZ ----------- -------------------------------------------------------------------------------- -------------------------------------------------------------------------------- -------------------------------------------------------------------------------- 2016/3/1 9: 01-3月 -16 09.22.33.000000 上午 01-3月 -16 09.22.33.000000 上午 +08:00 01-3月 -16 11.22.33.000000 上午 Oracle的備份與恢復
總結
以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作能帶來一定的幫助,如果有疑問大家可以留言交流。
- oracle日期時間型timestamp的深入理解
- oracle SCN跟TIMESTAMP之間轉換
- oracle中to_date詳細用法示例(oracle日期格式轉換)
- ORACLE時間函數(SYSDATE)深入理解
- Oracle to_date()函數的用法介紹
- sqlserver和oracle中對datetime進行條件查詢的一點區(qū)別小結
- sqlserver中delete、update中使用表別名和oracle的區(qū)別
- oracle中UPDATE nowait 的使用方法介紹
- ORACLE SQL-UPDATE、DELETE、INSERT優(yōu)化和使用技巧分享
- Oracle date如何比較大小分析
相關文章
Oracle cloud control 12c的啟動、關閉及獲取安裝信息的方法
這篇文章主要介紹了Oracle cloud control 12c的啟動、關閉及獲取安裝信息的方法,例如獲取安裝時設定的各類端口號,URL以及如何啟動、關閉cloud control等等,需要的朋友可以參考下2014-11-11