日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

oracle时区参考表,ORACLE 时区

發布時間:2025/3/12 编程问答 34 豆豆
生活随笔 收集整理的這篇文章主要介紹了 oracle时区参考表,ORACLE 时区 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

商業和數據庫很多時候必須跨時區工作,從9i開始,oracle環境開始有了時區意識,通過指定數據庫的時區和使用TIMESTAMP WITH TIME ZONE和TIMESTAMP WITH LOCAL TIME ZONE數據類型來實現該功能。

TIMESTAMP WITH TIME ZONE不會存儲數據庫時區,但是有一個指示用來說明該時間所使用的時區。TIMESTAMP WITH LOCAL TIME ZONE會同時存儲數據庫時區,并且會根據查詢客戶端的時區進行相應的轉換。

數據庫時區可以在創建時在create database命令中設置,也可以使用alter database set TIME_ZONE=...來修改。如果沒有特別的指定,默認的,數據庫將遵從主機操作系統時區設置,或者取自環境變量ORA_STDZ。所有支持的時區記錄在V$TIMEZONE_NAMES動態性能表中。時區有三種表示方法,全名、縮寫和相對于標準時間(格林威治時間)的固定偏移,比如標準時間相應的三種表示方法分別為:Etc/Greenwich、GMT和+00:00。

Oracle 9i 開始多了 3 個關于時間的數據類型:TIMESTAMP [(precision)] TIMESTAMP [(precision)] WITH TIME ZONE TIMESTAMP [(precision)] WITH LOCAL TIME ZONE,其中 TIMESTAMP [(precision)] WITH TIME ZONE 保存了時區信息。

1. Oracle 的時區設置

Oracle 的時區可以分為兩種,一種是數據庫的時區,一種是 session 時區,也就是客戶端連接時的時區(經過實驗,連接以后再修改客戶端的時區,session 的時區不會更改)。

數據庫的時區在創建數據庫時可以通過在 create database 語句中加上 SET TIME_ZONE = ' { { + | - } hh : mi | time_zone_region } ' 來指定,如果,不指定,默認是按照數據庫所在的操作系統時區來設定的。創建之后,可以通過 alter database 來修改。其中 time_zone_region 參數可以通過查詢 V$TIMEZONE_NAMES 動態視圖來獲得所有支持的值。修改之后,需要重啟數據庫才能生效。經常有人會碰到無法修改的情況:

SQL> alter database set time_zone='+06:00';

alter database set time_zone='+06:00'

*

ERROR at line 1:

ORA-02231: missing or invalid option to ALTER DATABASE

TOM 對此問題有過解釋,TIME_ZONE 的設定主要是為了 WITH LOCAL TIME ZONE,當 session 的時區和數據庫的時區不同時,oracle 根據時區的差距轉換到數據庫的時間,再保存到數據庫的 WITH LOCAL TIME ZONE 類型中,他是不保存時區的,所以需要 TIME_ZONE 來進行各種時區之間時間的轉換(WITH TIME ZONE 類型保存了原始的時區,所以不需要 TIM

總結

以上是生活随笔為你收集整理的oracle时区参考表,ORACLE 时区的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。