Oracle Study之--Oracle TimeZone升级 http://tiany.blog.51cto.com/513694/1411882 Oracle 10gR2升级到Oracle 11gR2 当Oracle database从10gR2升级到11gR2之后,需要升级timezone version,以下详细介绍了timezone的升级过程。 Oracle timezone 升级 背景描
Oracle Study之--Oracle TimeZone升级
http://tiany.blog.51cto.com/513694/1411882
Oracle 10gR2升级到Oracle 11gR2
当Oracle database从10gR2升级到11gR2之后,需要升级timezone version,以下详细介绍了timezone的升级过程。
Oracle timezone 升级
背景描述:
如果需要支持一个国际化的应用,那么数据库端的国际化特性的支持也就显得尤其重要。Oracle中有很多特性支持国际化,如字符集、时区等等。如果相关参数设置不当,或者由于对相关特性不够了解,以至于在设计阶段没有考虑完全,那么肯定会对应用造成一定的损失。
升级前准备:
SQL*Plus: Release 11.2.0.1.0 Production on Mon Mar 16 14:07:28 2015 Copyright (c) 1982, 2009, Oracle. All rights reserved. Connected to: Oracle Database 11g Enterprise Edition Release 11.2.0.1.0 - Production With the Partitioning, OLAP, Data Mining and Real Application Testing options SQL> select * from v$version; BANNER -------------------------------------------------------------------------------- Oracle Database 11g Enterprise Edition Release 11.2.0.1.0 - Production PL/SQL Release 11.2.0.1.0 - Production CORE 11.2.0.1.0 Production TNS for Linux: Version 11.2.0.1.0 - Production NLSRTL Version 11.2.0.1.0 - Production
查看数据库当前timezone 版本:
SQL> SELECT version FROM v$timezone_file; VERSION ---------- 4 根据当前timezone的版本,又分三种情况: 1)等于14:这已经是11g需要的版本了,所以升级前后都不需要做任何事,这种情况很罕见。 注意:11.2.0.1.0的timezone最高支持到11,可以通过升级数据库到11.2.0.3.0,将timezone升级到14 SQL> select * from v$version; BANNER ---------------------------------------------------------------------------- Oracle Database 11g Enterprise EditionRelease 11.2.0.1.0 - 64bit Production PL/SQL Release 11.2.0.1.0 - Production CORE 11.2.0.1.0 Production TNS for 64-bit Windows: Version 11.2.0.1.0- Production NLSRTL Version 11.2.0.1.0 – Production SQL> SELECT NAME,VALUE$ FROM PROPS$WHERE NAME='DST_PRIMARY_TT_VERSION'; NAME VALUE$ ----------------------------------------------------------------------- DST_PRIMARY_TT_VERSION 11 SQL> select * from v$version; BANNER -------------------------------------------------------------------------------- Oracle Database 11g Enterprise EditionRelease 11.2.0.3.0 - 64bit Production PL/SQL Release 11.2.0.3.0 - Production CORE 11.2.0.3.0 Production TNS for Linux: Version 11.2.0.3.0 -Production NLSRTL Version 11.2.0.3.0 – Production SQL> SELECT NAME,VALUE$ FROM PROPS$WHERE NAME='DST_PRIMARY_TT_VERSION'; NAME VALUE$ ------------------------------------------------------------------------------- DST_PRIMARY_TT_VERSION 14 2)高于14:升级前,必须得给11g软件打上该timezone版本的DST补丁,这种情况也很罕见。 3)低于14:大多数都是这种情况,在升级前不需要在11g软件层面打补丁,在升级后需要再数据库层面将Timezone升级至14,具体看后面的步骤 SQL> set linesize 120 SQL> r 1* SELECT PROPERTY_NAME, SUBSTR(property_value, 1, 30) value FROM DATABASE_PROPERTIES WHERE PROPERTY_NAME LIKE 'DST_%' ORDER BY PROPERTY_NAME PROPERTY_NAME VALUE ------------------------------ -------------------------------------------------- DST_PRIMARY_TT_VERSION 4 DST_SECONDARY_TT_VERSION 0 DST_UPGRADE_STATE NONE
准备升级timezone到11:
(升级到14出现以下错误) SQL> exec DBMS_DST.BEGIN_PREPARE(14); BEGIN DBMS_DST.BEGIN_PREPARE(14); END; * ERROR at line 1: ORA-30094: failed to find the time zone data file for version 14 in $ORACLE_HOME/oracore/zoneinfo ORA-06512: at "SYS.DBMS_DST", line 57 ORA-06512: at "SYS.DBMS_DST", line 1258 ORA-06512: at line 1 [oracle@rh55 ~]$ find $ORACLE_HOME -name 'zoneinfo' /u01/app/oracle/product/11.2.0/db_1/oracore/zoneinfo [oracle@rh55 ~]$ ls -l /u01/app/oracle/product/11.2.0/db_1/oracore/zoneinfo total 10092 drwxr-xr-x 2 oracle oinstall 4096 Mar 13 11:45 big drwxr-xr-x 2 oracle oinstall 4096 Mar 13 11:45 little -rw-r--r-- 1 oracle oinstall 5725 Jun 12 2009 readme.txt -rw-r--r-- 1 oracle oinstall 25681 Jul 16 2009 timezdif.csv -rw-r--r-- 1 oracle oinstall 792894 Jul 31 2009 timezlrg_10.dat -rw-r--r-- 1 oracle oinstall 787272 Jul 31 2009 timezlrg_11.dat -rw-r--r-- 1 oracle oinstall 493675 Jul 31 2009 timezlrg_1.dat -rw-r--r-- 1 oracle oinstall 507957 Jul 31 2009 timezlrg_2.dat -rw-r--r-- 1 oracle oinstall 527717 Jul 31 2009 timezlrg_3.dat -rw-r--r-- 1 oracle oinstall 531137 Jul 31 2009 timezlrg_4.dat -rw-r--r-- 1 oracle oinstall 587487 Jul 31 2009 timezlrg_5.dat -rw-r--r-- 1 oracle oinstall 586750 Jul 31 2009 timezlrg_6.dat -rw-r--r-- 1 oracle oinstall 601242 Jul 31 2009 timezlrg_7.dat -rw-r--r-- 1 oracle oinstall 616723 Jul 31 2009 timezlrg_8.dat -rw-r--r-- 1 oracle oinstall 801410 Jul 31 2009 timezlrg_9.dat -rw-r--r-- 1 oracle oinstall 345637 Jul 31 2009 timezone_10.dat -rw-r--r-- 1 oracle oinstall 345356 Jul 31 2009 timezone_11.dat -rw-r--r-- 1 oracle oinstall 274427 Jul 31 2009 timezone_1.dat -rw-r--r-- 1 oracle oinstall 274900 Jul 31 2009 timezone_2.dat -rw-r--r-- 1 oracle oinstall 286651 Jul 31 2009 timezone_3.dat -rw-r--r-- 1 oracle oinstall 286264 Jul 31 2009 timezone_4.dat -rw-r--r-- 1 oracle oinstall 286310 Jul 31 2009 timezone_5.dat -rw-r--r-- 1 oracle oinstall 286217 Jul 31 2009 timezone_6.dat -rw-r--r-- 1 oracle oinstall 286815 Jul 31 2009 timezone_7.dat -rw-r--r-- 1 oracle oinstall 302100 Jul 31 2009 timezone_8.dat -rw-r--r-- 1 oracle oinstall 351525 Jul 31 2009 timezone_9.dat 在zoneinfo目录下没有version 14的时区文件 准备升级timezone到11: SQL> exec DBMS_DST.BEGIN_PREPARE(11); PL/SQL procedure successfully completed. 查看升级准备信息: SQL> SELECT PROPERTY_NAME, SUBSTR(property_value, 1, 30) value 2 FROM DATABASE_PROPERTIES 3 WHERE PROPERTY_NAME LIKE 'DST_%' 4 ORDER BY PROPERTY_NAME; PROPERTY_NAME VALUE ------------------------------ ---------------------------------------- DST_PRIMARY_TT_VERSION 4 DST_SECONDARY_TT_VERSION 11 DST_UPGRADE_STATE PREPARE
准备升级工作:
SQL> BEGIN 2 DBMS_DST.FIND_AFFECTED_TABLES 3 (affected_tables => 'sys.dst$affected_tables', 4 log_errors => TRUE, 5 log_errors_table => 'sys.dst$error_table'); 6 END; 7 / PL/SQL procedure successfully completed. SQL> TRUNCATE TABLE SYS.DST$TRIGGER_TABLE; Table truncated. SQL> TRUNCATE TABLE sys.dst$affected_tables; Table truncated. SQL> TRUNCATE TABLE sys.dst$error_table; Table truncated. SQL> SELECT * FROM sys.dst$affected_tables; no rows selected SQL>SELECT * FROM sys.dst$error_table; no rows selected SQL> SELECT * FROM sys.dst$error_table where ERROR_NUMBER= '1883'; no rows selected SQL> SELECT * FROM sys.dst$error_table where ERROR_NUMBER= '1878'; no rows selected SQL> SELECT * FROM sys.dst$error_table where ERROR_NUMBER not in ('1878','1883'); no rows selected
结束升级准备:
SQL> EXEC DBMS_DST.END_PREPARE; PL/SQL procedure successfully completed. SQL> SELECT PROPERTY_NAME, SUBSTR(property_value, 1, 30) value 2 FROM DATABASE_PROPERTIES 3 WHERE PROPERTY_NAME LIKE 'DST_%' 4 ORDER BY PROPERTY_NAME; PROPERTY_NAME VALUE ------------------------------ ---------------------------------------- DST_PRIMARY_TT_VERSION 4 DST_SECONDARY_TT_VERSION 0 DST_UPGRADE_STATE NONE
升级过程:
SQL> shutdown immediate; Database closed. Database dismounted. ORACLE instance shut down. SQL> startup upgrade; ORACLE instance started. Total System Global Area 627732480 bytes Fixed Size 1338336 bytes Variable Size 427820064 bytes Database Buffers 192937984 bytes Redo Buffers 5636096 bytes Database mounted. Database opened. SQL> set serveroutput on SQL> purge dba_recyclebin; DBA Recyclebin purged. SQL> TRUNCATE TABLE SYS.DST$TRIGGER_TABLE; Table truncated. SQL> TRUNCATE TABLE sys.dst$affected_tables; Table truncated. SQL> TRUNCATE TABLE sys.dst$error_table; Table truncated. SQL> alter session set "_with_subquery"=materialize; Session altered. 将timezone version升级到11: SQL> EXEC DBMS_DST.BEGIN_UPGRADE(11); PL/SQL procedure successfully completed. SQL> SELECT PROPERTY_NAME, SUBSTR(property_value, 1, 30) value 2 FROM DATABASE_PROPERTIES 3 WHERE PROPERTY_NAME LIKE 'DST_%' 4 ORDER BY PROPERTY_NAME; PROPERTY_NAME VALUE ------------------------------ ---------------------------------------- DST_PRIMARY_TT_VERSION 11 DST_SECONDARY_TT_VERSION 4 DST_UPGRADE_STATE UPGRADE SQL> SELECT OWNER, TABLE_NAME, UPGRADE_IN_PROGRESS FROM ALL_TSTZ_TABLES where UPGRADE_IN_PROGRESS='YES'; OWNER TABLE_NAME UPG ------------------------------ ------------------------------ --- SYSMAN MGMT_PROV_NET_CONFIG YES SYSMAN MGMT_PROV_IP_RANGE YES SYSMAN MGMT_PROV_SUITE_INST_MEMBERS YES SYSMAN MGMT_PROV_BOOTSERVER YES SYSMAN AQ$_MGMT_NOTIFY_QTABLE_L YES SYSMAN AQ$_MGMT_LOADER_QTABLE_S YES SYSMAN AQ$_MGMT_LOADER_QTABLE_L YES SYSMAN AQ$_MGMT_NOTIFY_QTABLE_S YES SYSMAN MGMT_PROV_STAGING_DIRS YES SYSMAN MGMT_PROV_OPERATION YES SYSMAN MGMT_PROV_ASSIGNMENT YES OWNER TABLE_NAME UPG ------------------------------ ------------------------------ --- SYSMAN MGMT_CONFIG_ACTIVITIES YES SYSMAN MGMT_PROV_CLUSTER_NODES YES SYSMAN MGMT_PROV_RPM_REP YES SYSMAN MGMT_PROV_DEFAULT_IMAGE YES IX AQ$_STREAMS_QUEUE_TABLE_S YES IX AQ$_STREAMS_QUEUE_TABLE_L YES IX AQ$_ORDERS_QUEUETABLE_S YES IX AQ$_ORDERS_QUEUETABLE_L YES 19 rows selected. SQL> shutdown immediate; Database closed. Database dismounted. ORACLE instance shut down. SQL> startup ORACLE instance started. Total System Global Area 627732480 bytes Fixed Size 1338336 bytes Variable Size 427820064 bytes Database Buffers 192937984 bytes Redo Buffers 5636096 bytes Database mounted. Database opened. SQL> alter session set "_with_subquery"=materialize; Session altered. 执行timezone升级过程: SQL> set serveroutput on SQL> VAR numfail number SQL> BEGIN 2 DBMS_DST.UPGRADE_DATABASE(:numfail, 3 parallel => TRUE, 4 log_errors => TRUE, 5 log_errors_table => 'SYS.DST$ERROR_TABLE', 6 log_triggers_table => 'SYS.DST$TRIGGER_TABLE', 7 error_on_overlap_time => FALSE, 8 error_on_nonexisting_time => FALSE); 9 DBMS_OUTPUT.PUT_LINE('Failures:'|| :numfail); 10 END; 11 / Table list: SYSMAN.MGMT_PROV_SUITE_INST_MEMBERS Number of failures: 0 Table list: SYSMAN.MGMT_PROV_STAGING_DIRS Number of failures: 0 Table list: SYSMAN.MGMT_PROV_RPM_REP Number of failures: 0 Table list: SYSMAN.MGMT_PROV_OPERATION Number of failures: 0 Table list: SYSMAN.MGMT_PROV_NET_CONFIG Number of failures: 0 Table list: SYSMAN.MGMT_PROV_IP_RANGE Number of failures: 0 Table list: SYSMAN.MGMT_PROV_DEFAULT_IMAGE Number of failures: 0 Table list: SYSMAN.MGMT_PROV_CLUSTER_NODES Number of failures: 0 Table list: SYSMAN.MGMT_PROV_BOOTSERVER Number of failures: 0 Table list: SYSMAN.MGMT_PROV_ASSIGNMENT Number of failures: 0 Table list: SYSMAN.MGMT_CONFIG_ACTIVITIES Number of failures: 0 Table list: SYSMAN.AQ$_MGMT_NOTIFY_QTABLE_S Number of failures: 0 Table list: SYSMAN.AQ$_MGMT_NOTIFY_QTABLE_L Number of failures: 0 Table list: SYSMAN.AQ$_MGMT_LOADER_QTABLE_S Number of failures: 0 Table list: SYSMAN.AQ$_MGMT_LOADER_QTABLE_L Number of failures: 0 Table list: IX.AQ$_STREAMS_QUEUE_TABLE_S Number of failures: 0 Table list: IX.AQ$_STREAMS_QUEUE_TABLE_L Number of failures: 0 Table list: IX.AQ$_ORDERS_QUEUETABLE_S Number of failures: 0 Table list: IX.AQ$_ORDERS_QUEUETABLE_L Number of failures: 0 Failures:0 PL/SQL procedure successfully completed. 结束升级,校验升级信息: SQL> VAR fail number SQL> BEGIN 2 DBMS_DST.END_UPGRADE(:fail); 3 DBMS_OUTPUT.PUT_LINE('Failures:'|| :fail); 4 END; 5 / An upgrade window has been successfully ended. Failures:0 PL/SQL procedure successfully completed.
确认升级成功:
SQL> SELECT PROPERTY_NAME, SUBSTR(property_value, 1, 30) value 2 FROM DATABASE_PROPERTIES 3 WHERE PROPERTY_NAME LIKE 'DST_%' 4 ORDER BY PROPERTY_NAME; PROPERTY_NAME VALUE ------------------------------ ---------------------------------------- DST_PRIMARY_TT_VERSION 11 DST_SECONDARY_TT_VERSION 0 DST_UPGRADE_STATE NONE SQL> SELECT * FROM v$timezone_file; FILENAME VERSION -------------------- ---------- timezlrg_11.dat 11

InnoDB使用redologs和undologs確保數據一致性和可靠性。 1.redologs記錄數據頁修改,確保崩潰恢復和事務持久性。 2.undologs記錄數據原始值,支持事務回滾和MVCC。

EXPLAIN命令的關鍵指標包括type、key、rows和Extra。 1)type反映查詢的訪問類型,值越高效率越高,如const優於ALL。 2)key顯示使用的索引,NULL表示無索引。 3)rows預估掃描行數,影響查詢性能。 4)Extra提供額外信息,如Usingfilesort提示需要優化。

Usingtemporary在MySQL查詢中表示需要創建臨時表,常見於使用DISTINCT、GROUPBY或非索引列的ORDERBY。可以通過優化索引和重寫查詢避免其出現,提升查詢性能。具體來說,Usingtemporary出現在EXPLAIN輸出中時,意味著MySQL需要創建臨時表來處理查詢。這通常發生在以下情況:1)使用DISTINCT或GROUPBY時進行去重或分組;2)ORDERBY包含非索引列時進行排序;3)使用複雜的子查詢或聯接操作。優化方法包括:1)為ORDERBY和GROUPB

MySQL/InnoDB支持四種事務隔離級別:ReadUncommitted、ReadCommitted、RepeatableRead和Serializable。 1.ReadUncommitted允許讀取未提交數據,可能導致臟讀。 2.ReadCommitted避免臟讀,但可能發生不可重複讀。 3.RepeatableRead是默認級別,避免臟讀和不可重複讀,但可能發生幻讀。 4.Serializable避免所有並發問題,但降低並發性。選擇合適的隔離級別需平衡數據一致性和性能需求。

MySQL適合Web應用和內容管理系統,因其開源、高性能和易用性而受歡迎。 1)與PostgreSQL相比,MySQL在簡單查詢和高並發讀操作上表現更好。 2)相較Oracle,MySQL因開源和低成本更受中小企業青睞。 3)對比MicrosoftSQLServer,MySQL更適合跨平台應用。 4)與MongoDB不同,MySQL更適用於結構化數據和事務處理。

MySQL索引基数对查询性能有显著影响:1.高基数索引能更有效地缩小数据范围,提高查询效率;2.低基数索引可能导致全表扫描,降低查询性能;3.在联合索引中,应将高基数列放在前面以优化查询。

MySQL學習路徑包括基礎知識、核心概念、使用示例和優化技巧。 1)了解表、行、列、SQL查詢等基礎概念。 2)學習MySQL的定義、工作原理和優勢。 3)掌握基本CRUD操作和高級用法,如索引和存儲過程。 4)熟悉常見錯誤調試和性能優化建議,如合理使用索引和優化查詢。通過這些步驟,你將全面掌握MySQL的使用和優化。

MySQL在現實世界的應用包括基礎數據庫設計和復雜查詢優化。 1)基本用法:用於存儲和管理用戶數據,如插入、查詢、更新和刪除用戶信息。 2)高級用法:處理複雜業務邏輯,如電子商務平台的訂單和庫存管理。 3)性能優化:通過合理使用索引、分區表和查詢緩存來提升性能。


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

SublimeText3漢化版
中文版,非常好用

SAP NetWeaver Server Adapter for Eclipse
將Eclipse與SAP NetWeaver應用伺服器整合。

Dreamweaver Mac版
視覺化網頁開發工具

Safe Exam Browser
Safe Exam Browser是一個安全的瀏覽器環境,安全地進行線上考試。該軟體將任何電腦變成一個安全的工作站。它控制對任何實用工具的訪問,並防止學生使用未經授權的資源。

MinGW - Minimalist GNU for Windows
這個專案正在遷移到osdn.net/projects/mingw的過程中,你可以繼續在那裡關注我們。 MinGW:GNU編譯器集合(GCC)的本機Windows移植版本,可自由分發的導入函式庫和用於建置本機Windows應用程式的頭檔;包括對MSVC執行時間的擴展,以支援C99功能。 MinGW的所有軟體都可以在64位元Windows平台上運作。