教你怎樣在Oracle 9i中正確轉(zhuǎn)換時區(qū)數(shù)據(jù)庫 -電腦資料

電腦資料 時間:2019-01-01 我要投稿
【m.clearvueentertainment.com - 電腦資料】

    在 Oracle 9i之前,雖然有一個NEW_TIME函數(shù)可以改變DATE的時間戳部分,但是還沒有專門用來存儲時區(qū)信息的數(shù)據(jù)類型,

教你怎樣在Oracle 9i中正確轉(zhuǎn)換時區(qū)數(shù)據(jù)庫

。在Oracle9i中,我們可以使用DBTIMEZONE偽字段查詢 數(shù)據(jù)庫 的時區(qū),使用SESSIONTIMEZONE偽字段查詢會話的時區(qū)。 但是,對于大多數(shù)數(shù)據(jù)庫,這

    在Oracle9i之前,雖然有一個NEW_TIME函數(shù)可以改變DATE的時間戳部分,但是還沒有專門用來存儲時區(qū)信息的數(shù)據(jù)類型。在Oracle9i中,我們可以使用DBTIMEZONE偽字段查詢數(shù)據(jù)庫的時區(qū),使用SESSIONTIMEZONE偽字段查詢會話的時區(qū)。

    但是,對于大多數(shù)數(shù)據(jù)庫,這些值都是-07:00之類的偏移值,因此對于NEW_TIME函數(shù)是沒有用的。Oracle9i有關(guān)NEW_TIME的文檔建議使用FROM_TZ來替代,但是這可能會產(chǎn)生誤導(dǎo)。FROM_TZ只將一個時區(qū)應(yīng)用到一個時間戳上;它并不能把一個時區(qū)轉(zhuǎn)換成另外一個時區(qū)。

    其實有一個比較好的方法(從文檔中得到這個方法可能有點難)。首先,為了完成這個工作,在正確的時區(qū)內(nèi)需要一個TIMESTAMP WITH ZONE數(shù)據(jù)類型。然后,如果你將關(guān)鍵字AT TIME ZONE應(yīng)用到那個值,它就會自動地調(diào)整為新的時區(qū)和日期。

   

<PRE><CCID_CODE>select (timestamp '2003-04-06 01:59:59' at time zone 'PDT') at time zone 'GMT'from dual;06-APR-03 08.59.59.00000000 AM GMT</PRE>

    這個語句將為太平洋白天時間(即其切換到PST之前的時刻)構(gòu)造一個TIMESTAMP WITH TIME ZONE然后再將其轉(zhuǎn)換到GMT。AT TIME ZONE關(guān)鍵字也接受默認的偏移值語法:

   

<PRE><CCID_CODE>select (timestamp '2003-04-06 02:00:00' at time zone '-07:00') at time zone'00:00' from dual;06-APR-03 09.00.00.000000000 AM +00:00</PRE>

    你還可以使用偽字段來自動調(diào)整當前會話的時區(qū):

   

<PRE><CCID_CODE>selectcurrent_timestamp at time zone dbtimezone from dual;</PRE>

    上面的表達式返回一個當前會話的本地時間(數(shù)據(jù)類型為時區(qū)),重新調(diào)整數(shù)據(jù)庫的時區(qū),調(diào)整后的時區(qū)將與SYSTIMESTAMP的結(jié)果相等,

電腦資料

教你怎樣在Oracle 9i中正確轉(zhuǎn)換時區(qū)數(shù)據(jù)庫》(http://m.clearvueentertainment.com)。

    有了以上的這些信息,就可以構(gòu)造一個比較好的NEW_TIME函數(shù):

   

<PRE><CCID_CODE>create or replace function my_new_time(p_dwtz timestamp with time zone,p_tz varchar2) return dateisbeginreturn cast(p_dwtz at time zone p_tz as date);end my_new_time;/show errors;select my_new_time(sysdate,'+08:00') from dual;</PRE>

    即使第一個參數(shù)被標記為一個timestamp with time zone,你依然可以傳入一個TIMESTAMP和DATE,這樣由于Oracle的自動轉(zhuǎn)型操作,得到的時間將是會話在本地時區(qū)的當前時間。這個函數(shù)接受包括偏移值在內(nèi)的任何可以被TIMESTAMP識別的時區(qū),然后將接受的時區(qū)調(diào)整為正確的值。

    (責任編輯 火鳳凰 sunsj@51cto.com TEL:(010)68476636-8007)

    原文轉(zhuǎn)自:http://www.ltesting.net

最新文章