新聞中心
這篇文章主要為大家展示了“Oracle如何修改時區(qū)”,內(nèi)容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領(lǐng)大家一起研究并學(xué)習(xí)一下“Oracle如何修改時區(qū)”這篇文章吧。
成都網(wǎng)絡(luò)公司-成都網(wǎng)站建設(shè)公司創(chuàng)新互聯(lián)十余年經(jīng)驗成就非凡,專業(yè)從事成都網(wǎng)站建設(shè)、成都網(wǎng)站制作,成都網(wǎng)頁設(shè)計,成都網(wǎng)頁制作,軟文平臺,一元廣告等。十余年來已成功提供全面的成都網(wǎng)站建設(shè)方案,打造行業(yè)特色的成都網(wǎng)站建設(shè)案例,建站熱線:18980820575,我們期待您的來電!
Oracle修改時區(qū)
1. 首先確認會話時區(qū)是否正確,會話時區(qū)可能和數(shù)據(jù)庫時區(qū)不一致
SQL> select sessiontimezone from dual;
SESSIONTIMEZONE
---------------------------------------------------------------------------
+08:00
會話時區(qū)是北京時區(qū)
SQL> select dbtimezone from dual;
DBTIME
------
+00:00
DB是世界時區(qū)
SQL> select tz_offset(sessiontimezone), tz_offset(dbtimezone) from dual;
TZ_OFFS TZ_OFFS
------- -------
+08:00 +00:00
2. 檢查數(shù)據(jù)庫是否有這樣的字段類型 TIMESTAMP WITH LOCAL TIME ZONE
SQL> select c.owner || '.' || c.table_name || '(' || c.column_name || ') -'
|| c.data_type || ' ' col
from dba_tab_cols c, dba_objects o
where c.data_type like '%WITH LOCAL TIME ZONE'
and c.owner=o.owner
and c.table_name = o.object_name
and o.object_type = 'TABLE'
order by col
/
COL
--------------------------------------------------------------------------------
OE.ORDERS(ORDER_DATE) -TIMESTAMP(6) WITH LOCAL TIME ZONE
--查看時區(qū)依賴的表
SQL> select u.name || '.' || o.name || '.' || c.name TSLTZcolumn
from sys.obj$ o, sys.col$ c, sys.user$ u
where c.type# = 231
and o.obj# = c.obj#
and u.user# = o.owner#;
TSLTZCOLUMN
--------------------------------------------------------------------------------
OE.ORDERS.ORDER_DATE
3. 查看時區(qū)依賴表結(jié)構(gòu)
SQL> desc oe.orders
Name Null? Type
----------------------------------------- -------- ----------------------------
ORDER_ID NOT NULL NUMBER(12)
ORDER_DATE NOT NULL TIMESTAMP(6) WITH LOCAL TIME
ZONE
ORDER_MODE VARCHAR2(8)
CUSTOMER_ID NOT NULL NUMBER(6)
ORDER_STATUS NUMBER(2)
ORDER_TOTAL NUMBER(8,2)
SALES_REP_ID NUMBER(6)
PROMOTION_ID NUMBER(6)
4. 查看時區(qū)依賴表數(shù)據(jù)
SQL> select ORDER_DATE from oe.orders;
ORDER_DATE
---------------------------------------------------------------------------
21-MAR-04 08.18.21.862632 AM
09-JAN-06 12.19.44.123456 PM
09-JAN-06 01.34.13.112233 PM
27-JAN-06 01.22.51.962632 AM
02-FEB-06 05.34.56.345678 PM
03-FEB-06 12.19.11.227550 PM
28-FEB-06 09.03.03.828330 AM
30-MAR-06 02.22.09.509801 AM
30-MAR-06 05.34.50.545196 AM
28-JUL-06 02.22.59.662632 AM
28-JUL-06 03.34.16.562632 AM
..................................
28-JUN-08 11.53.32.335522 AM
15-JUL-08 08.18.23.234567 AM
27-JUL-08 10.59.10.223344 PM
02-AUG-08 01.22.48.734526 AM
105 rows selected.
5. 處理時區(qū)依賴表
(1) 創(chuàng)建臨時表進行備份
SQL> create table oe.test1(order_id number,order_date date);
Table created.
SQL> insert into oe.test1(order_id,order_date) select order_id,order_date from oe.orders;
105 rows created.
SQL> commit;
Commit complete.
(2) 處理原表oe.orders中的列order_date
SQL> alter table oe.orders drop column order_date;
Table altered.
SQL> alter table oe.orders add order_date date;
Table altered.
SQL> update oe.orders a set order_date= (select order_date from oe.test1 b where a.order_id=b.order_id);
105 rows updated.
SQL> commit;
Commit complete.
(3) 再次查詢是否還存在以上類型的列
SQL> select c.owner || '.' || c.table_name || '(' || c.column_name || ') -'
|| c.data_type || ' ' col
from dba_tab_cols c, dba_objects o
where c.data_type like '%WITH LOCAL TIME ZONE'
and c.owner=o.owner
and c.table_name = o.object_name
and o.object_type = 'TABLE'
order by col
/
no rows selected
SQL> select u.name || '.' || o.name || '.' || c.name TSLTZcolumn
from sys.obj$ o, sys.col$ c, sys.user$ u
where c.type# = 231
and o.obj# = c.obj#
and u.user# = o.owner#;
no rows selected
6. 修改時區(qū),但是查詢還是未生效
SQL> alter database set time_zone='+8:00';
Database altered.
SQL> select dbtimezone from dual;
DBTIME
------
+00:00
7. 重啟數(shù)據(jù)庫,時區(qū)生效
SQL> shutdown immediate;
Database closed.
Database dismounted.
ORACLE instance shut down.
SQL>
SQL> startup
ORACLE instance started.
Total System Global Area 835104768 bytes
Fixed Size 2257840 bytes
Variable Size 549456976 bytes
Database Buffers 281018368 bytes
Redo Buffers 2371584 bytes
Database mounted.
Database opened.
SQL>
SQL> select dbtimezone from dual;
DBTIME
------
+08:00
SQL> select tz_offset(sessiontimezone), tz_offset(dbtimezone) from dual;
TZ_OFFS TZ_OFFS
------- -------
+08:00 +08:00
8. 刪除臨時表
SQL> drop table oe.test1 purge;
Table dropped.
另外:
對于全球化的業(yè)務(wù)而言,業(yè)務(wù)必須在多個時區(qū)之間正常運轉(zhuǎn)。從9i版本開始,Oracle環(huán)境能夠知道所使用時區(qū)。為了實現(xiàn)這個功能,需要指定數(shù)據(jù)庫所運行的時區(qū)以及使用TIMESTAMP WITH TIME ZONE與TIMESTAMP WITH LOCAL TIME ZONE數(shù)據(jù)類型。前一種具有一個時區(qū)指示符,這個指示符說明了其引用的時區(qū)。后一種數(shù)據(jù)類型在存儲時會被規(guī)范化為數(shù)據(jù)庫時區(qū),但隨后在檢索時會轉(zhuǎn)換為客戶端的時區(qū)。普通的DATE和TIMESTAMP數(shù)據(jù)類型在存儲時始終會規(guī)范為數(shù)據(jù)庫時區(qū),并且會在查詢過程原樣顯示。
關(guān)于timestamp的幾個函數(shù):
sysdate 數(shù)據(jù)庫服務(wù)器操作系統(tǒng)時間,顯示不含時區(qū)(其實隱含了時區(qū))。
systimestamp 數(shù)據(jù)庫服務(wù)器操作系統(tǒng)時間以及時區(qū)
注意:上述兩個函數(shù)的返回值不會受到客戶端影響。
localtimestamp 根據(jù)客戶端時區(qū)轉(zhuǎn)換成客戶端當(dāng)前時間,但顯示并不含時區(qū)
current_timestamp 根據(jù)客戶端時區(qū)轉(zhuǎn)換成客戶端當(dāng)前時間,包含客戶端時區(qū)
注意:上述兩個函數(shù)的返回值和客戶端時區(qū)設(shè)置有關(guān),會轉(zhuǎn)換為客戶端時區(qū)的時間。
以上是“Oracle如何修改時區(qū)”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學(xué)習(xí)更多知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!
分享名稱:Oracle如何修改時區(qū)
網(wǎng)址分享:http://fisionsoft.com.cn/article/gijdio.html