国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 數據庫 > Oracle > 正文

教你怎樣在Oracle 9i中正確轉換時區

2024-08-29 13:50:49
字體:
來源:轉載
供稿:網友
在Oracle9i之前,雖然有一個NEW_TIME函數可以改變DATE的時間戳部分,但是還沒有專門用來存儲時區信息的數據類型。在Oracle9i中,我們可以使用DBTIMEZONE偽字段查詢數據庫的時區,使用sessionTIMEZONE偽字段查詢會話的時區。 但是,對于大多數數據庫,這些值都是-07:00之類的偏移值,因此對于NEW_TIME函數是沒有用的。Oracle9i有關NEW_TIME的文檔建議使用FROM_TZ來替代,但是這可能會產生誤導。FROM_TZ只將一個時區應用到一個時間戳上;它并不能把一個時區轉換成另外一個時區。 其實有一個比較好的方法(從文檔中得到這個方法可能有點難)。首先,為了完成這個工作,在正確的時區內需要一個TIMESTAMP WITH ZONE數據類型。然后,假如你將要害字AT TIME ZONE應用到那個值,它就會自動地調整為新的時區和日期。
    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
這個語句將為太平洋白天時間(即其切換到PST之前的時刻)構造一個TIMESTAMP WITH TIME ZONE然后再將其轉換到GMT。AT TIME ZONE要害字也接受默認的偏移值語法:
    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 
你還可以使用偽字段來自動調整當前會話的時區:
    selectcurrent_timestamp at time zone dbtimezone from dual;
上面的表達式返回一個當前會話的本地時間(數據類型為時區),重新調整數據庫的時區,調整后的時區將與SYSTIMESTAMP的結果相等。 有了以上的這些信息,就可以構造一個比較好的NEW_TIME函數:
    create or replace function my_new_time  (    p_dwtz timestamp with time zone,    p_tz varchar2  ) return date  is  begin    return 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;
即使第一個參數被標記為一個timestamp with time zone,你依然可以傳入一個TIMESTAMP和DATE,這樣由于Oracle的自動轉型操作,得到的時間將是會話在本地時區的當前時間。這個函數接受包括偏移值在內的任何可以被TIMESTAMP識別的時區,然后將接受的時區調整為正確的值。


上一篇:Oracle數據庫中SQL語句性能調整原則

下一篇:復雜應用環境下監控Oracle數據庫性能

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
學習交流
熱門圖片

新聞熱點

疑難解答

圖片精選

網友關注

主站蜘蛛池模板: 高要市| 阳曲县| 白河县| 泰来县| 尉犁县| 西平县| 家居| 罗定市| 抚顺市| 利川市| 恩平市| 凌云县| 湘阴县| 五华县| 句容市| 孟村| 库尔勒市| 安达市| 安多县| 井研县| 抚顺市| 荥阳市| 屯留县| 余姚市| 义乌市| 河源市| 峨眉山市| 松潘县| 靖西县| 安远县| 进贤县| 建平县| 泾源县| 莎车县| 堆龙德庆县| 东辽县| 开封县| 顺昌县| 界首市| 江山市| 星座|