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

首頁(yè) > 數(shù)據(jù)庫(kù) > Oracle > 正文

在oracle9i正確轉(zhuǎn)換時(shí)區(qū)

2024-08-29 13:41:31
字體:
供稿:網(wǎng)友

  在Oracle9i之前,雖然有一個(gè)NEW_TIME函數(shù)可以改變DATE的時(shí)間戳部分,但是還沒有專門用來存儲(chǔ)時(shí)區(qū)信息的數(shù)據(jù)類型。在Oracle9i中,我們可以使用DBTIMEZONE偽字段查詢數(shù)據(jù)庫(kù)的時(shí)區(qū),使用sessionTIMEZONE偽字段查詢會(huì)話的時(shí)區(qū)。
  
  但是,對(duì)于大多數(shù)數(shù)據(jù)庫(kù),這些值都是-07:00之類的偏移值,因此對(duì)于NEW_TIME函數(shù)是沒有用的。Oracle9i有關(guān)NEW_TIME的文檔建議使用FROM_TZ來替代,但是這可能會(huì)產(chǎn)生誤導(dǎo)。FROM_TZ只將一個(gè)時(shí)區(qū)應(yīng)用到一個(gè)時(shí)間戳上;它并不能把一個(gè)時(shí)區(qū)轉(zhuǎn)換成另外一個(gè)時(shí)區(qū)。
  
  其實(shí)有一個(gè)比較好的方法(從文檔中得到這個(gè)方法可能有點(diǎn)難)。首先,為了完成這個(gè)工作,在正確的時(shí)區(qū)內(nèi)需要一個(gè)TIMESTAMP WITH ZONE數(shù)據(jù)類型。然后,假如你將要害字AT TIME ZONE應(yīng)用到那個(gè)值,它就會(huì)自動(dòng)地調(diào)整為新的時(shí)區(qū)和日期。
  
  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
  
  這個(gè)語句將為太平洋白天時(shí)間(即其切換到PST之前的時(shí)刻)構(gòu)造一個(gè)TIMESTAMP WITH TIME ZONE然后再將其轉(zhuǎn)換到GMT。AT TIME ZONE要害字也接受默認(rèn)的偏移值語法:
  
  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
  
  你還可以使用偽字段來自動(dòng)調(diào)整當(dāng)前會(huì)話的時(shí)區(qū):
  
  selectcurrent_timestamp at time zone dbtimezone from dual;
  
  上面的表達(dá)式返回一個(gè)當(dāng)前會(huì)話的本地時(shí)間(數(shù)據(jù)類型為時(shí)區(qū)),重新調(diào)整數(shù)據(jù)庫(kù)的時(shí)區(qū),調(diào)整后的時(shí)區(qū)將與SYSTIMESTAMP的結(jié)果相等。
  
  有了以上的這些信息,就可以構(gòu)造一個(gè)比較好的NEW_TIME函數(shù):
  
  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;
  
  即使第一個(gè)參數(shù)被標(biāo)記為一個(gè)timestamp with time zone,你依然可以傳入一個(gè)TIMESTAMP和DATE,這樣由于Oracle的自動(dòng)轉(zhuǎn)型操作,得到的時(shí)間將是會(huì)話在本地時(shí)區(qū)的當(dāng)前時(shí)間。這個(gè)函數(shù)接受包括偏移值在內(nèi)的任何可以被TIMESTAMP識(shí)別的時(shí)區(qū),然后將接受的時(shí)區(qū)調(diào)整為正確的值。

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 乌兰浩特市| 洪湖市| 广东省| 获嘉县| 民乐县| 普安县| 合川市| 尚义县| 阜康市| 南漳县| 玉门市| 温州市| 仪陇县| 吉木萨尔县| 苗栗市| 清水河县| 永顺县| 南充市| 华蓥市| 新昌县| 吴桥县| 华阴市| 黄石市| 新和县| 怀来县| 丘北县| 江城| 嘉鱼县| 尼木县| 邢台市| 葫芦岛市| 南汇区| 蒙山县| 澄城县| 津市市| 延津县| 盐边县| 东丰县| 长海县| 三门峡市| 桓仁|