對於同義字的備份我們有多種方式來實現,如直接通過指令碼產生同義字的建立指令碼,或者使用dbms_metadata.get_ddl來提取同義字的定義指令碼。然而在使用傳統的exp或是datapump expdp實現schema層級資料移轉時,不能匯出公用同義字。儘管如此,我們依舊可以使用匯出匯入的方式來實現。所不同的是,我們使用FULL=Y的方式來單獨匯出同義字,然後再將其匯入的目標資料庫。下文是對此進行的描述,末尾也給出了手動建立同義字的指令碼。
1、環境
--來源資料庫SQL> select * from v$version where rownum<2;BANNER----------------------------------------------------------------Oracle Database 10g Release 10.2.0.3.0 - 64bit ProductionSQL> show parameter db_namNAME TYPE VALUE------------------------------------ ----------- ------------------------------db_name string XM6320SQL> select count(*) from dba_synonyms where table_owner='GOEX_ADMIN'; COUNT(*)---------- 1042--目標資料庫--目標資料庫schema goex_admin的所有資料均來源於來源資料庫,但是使用datapump匯入後,無同義字SQL> select * from v$version where rownum<2;BANNER----------------------------------------------------------------Oracle Database 10g Release 10.2.0.3.0 - 64bit ProductionSQL> show parameter db_nameNAME TYPE VALUE------------------------------------ ----------- ------------------------------db_name string KM3625--下面的查詢中僅有兩個同義字,這兩個同義是在建立DB的時候手動建立的,非使用datapump匯入產生的SQL> select count(*) from dba_synonyms where table_owner='GOEX_ADMIN'; COUNT(*)---------- 2
2、從來源資料庫匯出公用同義字
oracle@BKDB01p:~> env | grep SIDORACLE_SID=XM6320#使用下面的方式匯出公用同義字,對於可匯出的對象我們可以查詢資料字典 DATABASE_EXPORT_OBJECTSoracle@BKDB01p:~> expdp goex_admin/xxx directory=db_dump_dir dumpfile=syns.dmp logfile=exp_syns.log full=y \> include=PUBLIC_SYNONYM/SYNONYM:\"IN \(SELECT synonym_name FROM dba_synonyms WHERE table_owner=\'GOEX_ADMIN\'\)\"Export: Release 10.2.0.3.0 - 64bit Production on Wednesday, 19 June, 2013 16:11:19Copyright (c) 2003, 2005, Oracle. All rights reserved.Connected to: Oracle Database 10g Release 10.2.0.3.0 - 64bit ProductionStarting "GOEX_ADMIN"."SYS_EXPORT_FULL_01": goex_admin/******** directory=db_dump_dir dumpfile=syns.dmp logfile=exp_syns.log full=y include=PUBLIC_SYNONYM/SYNONYM:"IN (SELECT synonym_name FROM dba_synonyms WHERE table_owner='GOEX_ADMIN')"Estimate in progress using BLOCKS method...Processing object type DATABASE_EXPORT/SCHEMA/TABLE/TABLE_DATATotal estimation using BLOCKS method: 0 KBProcessing object type DATABASE_EXPORT/SCHEMA/PUBLIC_SYNONYM/SYNONYMMaster table "GOEX_ADMIN"."SYS_EXPORT_FULL_01" successfully loaded/unloaded******************************************************************************Dump file set for GOEX_ADMIN.SYS_EXPORT_FULL_01 is: /u02/database/XM6320/BNR/dump/syns.dmpJob "GOEX_ADMIN"."SYS_EXPORT_FULL_01" successfully completed at 16:11:23
3、匯入公用同義字到目標資料庫
oracle@BKDB01p:~> cp /u02/database/XM6320/BNR/dump/syns.dmp /u02/database/KM3625/BNR/dump/oracle@BKDB01p:~> export ORACLE_SID=KM3625oracle@BKDB01p:~> impdp goex_admin/xxx directory=db_dump_dir dumpfile=syns.dmp logfile=imp_syns.log full=y include=synonymImport: Release 10.2.0.3.0 - 64bit Production on Wednesday, 19 June, 2013 16:15:52Copyright (c) 2003, 2005, Oracle. All rights reserved.Connected to: Oracle Database 10g Release 10.2.0.3.0 - 64bit ProductionMaster table "GOEX_ADMIN"."SYS_IMPORT_FULL_01" successfully loaded/unloadedStarting "GOEX_ADMIN"."SYS_IMPORT_FULL_01": goex_admin/******** directory=db_dump_dir dumpfile=syns.dmp logfile=imp_syns.log full=y include=synonymProcessing object type DATABASE_EXPORT/SCHEMA/PUBLIC_SYNONYM/SYNONYMORA-31684: Object type SYNONYM:"PUBLIC"."GO_GA_SYS_DATAPUMP_PARA_TBL" already existsORA-31684: Object type SYNONYM:"PUBLIC"."BO_SYS_DATAPUMP_PKG" already existsJob "GOEX_ADMIN"."SYS_IMPORT_FULL_01" completed with 2 error(s) at 16:16:12#上面的匯入處理程序可以看到,Processing object type DATABASE_EXPORT/SCHEMA/PUBLIC_SYNONYM/SYNONYM實現了同義字的匯入#同時由於有兩個同義字存在,也給出了提示#驗證匯入的同義字oracle@BKDB01p:~> sqlplus / as sysdbaSQL*Plus: Release 10.2.0.3.0 - Production on Wed Jun 19 16:16:24 2013Copyright (c) 1982, 2006, Oracle. All Rights Reserved.Connected to:Oracle Database 10g Release 10.2.0.3.0 - 64bit ProductionSQL> show parameter db_nameNAME TYPE VALUE------------------------------------ ----------- ------------------------------db_name string KM3625SQL> select count(*) from dba_synonyms where table_owner='GOEX_ADMIN'; COUNT(*)---------- 1042
4、手動建立同義字的指令碼
ACCEPT input_owner PROMPT 'Enter the owner of table:'SET HEADING OFF VERIFY OFF FEEDBACK OFF TERMOUT OFF;SPOOL $LOG/create_synonym.sql--Author: Robinson--Blog : http://blog.csdn.net/robinson_0612SELECT 'create public synonym ' || synonym_name || ' for ' || table_owner || '.' || table_name || ';' FROM dba_synonyms s WHERE s.owner = 'PUBLIC' AND s.table_owner = UPPER ('&input_owner');SET HEADING ON VERIFY ON TERMOUT ON FEEDBACK OFF;SPOOL OFF;--@$LOG/create_synonym.sql;
5、相關參考
資料泵 EXPDP 匯出工具的使用
資料泵 IMPDP 匯入工具的使用
expdp impdp中 exclude/include 的使用
使用 Oracle Datapump API 實現資料匯出
匯入匯出 Oracle 分區表資料
Oracle datapump expdp/impdp 匯入匯出資料庫時hang住
更多參考
有關Oracle RAC請參考
使用crs_setperm修改RAC資源的所有者及許可權
使用crs_profile管理RAC資源設定檔
RAC 資料庫的啟動與關閉
再說 Oracle RAC services
Services in Oracle Database 10g
Migrate datbase from single instance to Oracle RAC
Oracle RAC 串連到指定執行個體
Oracle RAC 負載平衡測試(結合伺服器端與用戶端)
Oracle RAC 伺服器端串連負載平衡(Load Balance)
Oracle RAC 用戶端串連負載平衡(Load Balance)
ORACLE RAC 下非預設連接埠監聽配置(listener.ora tnsnames.ora)
ORACLE RAC 監聽配置 (listener.ora tnsnames.ora)
配置 RAC 負載平衡與容錯移轉
CRS-1006 , CRS-0215 故障一例
基於Linux (RHEL 5.5) 安裝Oracle 10g RAC
使用 runcluvfy 校正Oracle RAC安裝環境
有關Oracle 網路設定相關基礎以及概念性的問題請參考:
配置非預設連接埠的動態服務註冊
配置sqlnet.ora限制IP訪問Oracle
Oracle 監聽器日誌配置與管理
設定 Oracle 監聽器密碼(LISTENER)
配置ORACLE 用戶端串連到資料庫
有關基於使用者管理的備份和備份恢複的概念請參考
Oracle 冷備份
Oracle 熱備份
Oracle 備份恢複概念
Oracle 執行個體恢複
Oracle 基於使用者管理恢複的處理
SYSTEM 資料表空間管理及備份恢複
SYSAUX資料表空間管理及恢複
Oracle 基於備份控制檔案的恢複(unsing backup controlfile)
有關RMAN的備份恢複與管理請參考
RMAN 概述及其體繫結構
RMAN 配置、監控與管理
RMAN 備份詳解
RMAN 還原與恢複
RMAN catalog 的建立和使用
基於catalog 建立RMAN儲存指令碼
基於catalog 的RMAN 備份與恢複
RMAN 備份路徑困惑
使用RMAN實現異機備份恢複(WIN平台)
使用RMAN遷移檔案系統資料庫到ASM
linux 下RMAN備份shell指令碼
使用RMAN遷移資料庫到異機
有關ORACLE體繫結構請參考
Oracle 資料表空間與資料檔案
Oracle 密碼檔案
Oracle 參數檔案
Oracle 聯機重做記錄檔(ONLINE LOG FILE)
Oracle 控制檔案(CONTROLFILE)
Oracle 歸檔日誌
Oracle 復原(ROLLBACK)和撤銷(UNDO)
Oracle 資料庫執行個體啟動關閉過程
Oracle 10g SGA 的自動化管理
Oracle 執行個體和Oracle資料庫(Oracle體繫結構)