国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

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

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

瀏覽:103日期: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 數據庫
主站蜘蛛池模板: 日韩精品特黄毛片免费看 | 日本aaaa片毛片免费 | 99爱视频在线 | 亚洲成年人专区 | 热久久在线观看 | 国产精品久久久久毛片 | 国产一区二区三区在线看 | 大视频在线爱爱爱爱 | 韩国一级毛片在线观看 | 亚洲精品一区二区三区在线观看 | 久久精品视频2 | 最新步兵社区在线观看 | 66精品| 免费高清毛片在线播放视频 | 国产一级一片免费播放视频 | 色综合在 | 国产美女又黄又爽又色视频免费 | 亚洲欧美精品中字久久99 | 亚洲精品视频区 | 亚洲欧洲日韩综合色天使不卡 | 国产日本在线视频 | 亚洲韩国日本欧美一区二区三区 | 在线观看香蕉免费啪在线观看 | 久久一区二区三区免费播放 | 黄色三级视频在线播放 | 日韩在线高清 | 一本不卡 | 日韩男人的天堂 | 美女脱了内裤张开腿让男人桶网站 | 一区欧美| 久久频这里精品99香蕉久网址 | 91麻精品国产91久久久久 | 日本免费一区二区三区a区 日本免费一区二区三区看片 | 欧美高清一区二区三区欧美 | 欧美一区二区三区精品国产 | 在线 | 一区二区三区 | 日韩毛片大全免费高清 | 国产成人精品日本亚洲专 | 在线播放国产真实女同事 | 亚洲视频三区 | 欧日韩美香蕉在线观看 |