亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁技術文章
文章詳情頁

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

瀏覽:106日期:2023-11-13 12:38:44
在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 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;即使第一個參數被標記為一個timestamp with time zone,你依然可以傳入一個TIMESTAMP和DATE,這樣由于Oracle的自動轉型操作,得到的時間將是會話在本地時區的當前時間。這個函數接受包括偏移值在內的任何可以被TIMESTAMP識別的時區,然后將接受的時區調整為正確的值。
標簽: Oracle 數據庫
主站蜘蛛池模板: 黑人尻逼 | 国产欧美日韩精品在线 | 免费观看国产精品 | 一级特黄特色的免费大片视频 | 亚洲黄页 | 看毛片软件 | 精品久久久久不卡无毒 | 国产毛片一区二区三区 | 久久久久久在线 | 久草综合视频 | 午夜影院性 | 欧美精品v国产精品v | 国产视频首页 | 久久精品天天爽夜夜爽 | 欧美日韩在线观看一区二区 | 日韩亚洲国产欧美精品 | 色系视频在线观看免费观看 | 亚洲欧美日韩激情在线观看 | 综合区小说区图片区在线一区 | 国产大片黄在线播放 | 久久精品国产亚洲香蕉 | 成人在线免费视频观看 | 国产伦一区二区三区四区久久 | 国产在线丝袜 | 色老99久久九九爱精品69堂 | 蜜桃嫩草 | 欧美伦理三级在线播放影院 | 成人国内精品久久久久影 | 国产福利精品一区二区 | 搞黄在线观看 | 国产成人经典三级在线观看 | 婷婷五月色综合香五月 | 青青青草网站免费视频在线观看 | 亚洲精品久久玖玖玖玖 | 亚洲欧美在线观看一区二区 | 一级做a爰毛片 | 国产呦精品系列在线 | 51国产在线| 91进入蜜桃臀在线播放 | 正在播放淫亚洲 | 97碰碰碰免费公开在线视频 |