使用 Oracle Data Pump 匯入 - Amazon Relational Database Service

本文為英文版的機器翻譯版本,如內容有任何歧義或不一致之處,概以英文版為準。

使用 Oracle Data Pump 匯入

Oracle Data Pump 是一個公用程式,可讓您將 Oracle 資料匯出至傾印檔案,並將其匯入至另一個 Oracle 資料庫。是 Oracle 匯出/匯入公用程式的長期替代方案。Oracle Data Pump 是將大量資料從 Oracle 資料庫移至 Amazon RDS 資料庫執行個體的建議方法。

本節中的範例顯示將資料匯入 Oracle 資料庫的一種方法,但是 Oracle Data Pump 支援其他技術。如需詳細資訊,請參閱 Oracle 資料庫文件

本節中的範例使用 DBMS_DATAPUMP 套件。您可以使用 Oracle Data Pump 命令列公用程式 impdpexpdp 來完成相同的工作。您可以在安裝 Oracle 用戶端 (包括 Oracle Instant Client) 期間,將這些公用程式安裝在遠端主機上。如需詳細資訊,請參閱如何使用 Oracle Instant Client 為 Amazon RDS for Oracle 資料庫執行個體執行資料幫浦匯入或匯出?

Oracle Data Pump 概觀

Oracle Data Pump 由下列元件組成:

  • 命令列用戶端 expdpimpdp

  • PL/ DBMS_DATAPUMP SQL 套件

  • PL/ DBMS_METADATA SQL 套件

Oracle Data Pump 可以用於以下案例:

  • 從 Oracle 資料庫將資料匯入至RDS適用於 Oracle 資料庫執行個體的 ,無論是內部部署或 Amazon EC2執行個體。

  • 將資料從 RDS for Oracle 資料庫執行個體匯入 Oracle 資料庫,無論是內部部署或 Amazon EC2執行個體。

  • 匯入 RDS Oracle 資料庫執行個體的資料,例如,將資料從 EC2-Classic 遷移至 VPC。

如需下載 Oracle Data Pump 公用程式,請參閱 Oracle Technology Network 網站的 Oracle 資料庫軟體下載。如需了解在 Oracle 資料庫各版本間遷移的相容性考量,請參閱 Oracle 資料庫文件

Oracle Data Pump 工作流程

通常,您會在下列階段使用 Oracel Data Pump:

  1. 將資料匯出至來源資料庫上的傾印檔案。

  2. 將傾印檔案上傳至 Oracle 資料庫執行個體RDS的目的地。您可使用 Amazon S3 儲存貯體或兩個資料庫之間的資料庫連結進行傳輸。

  3. 將資料從傾印檔案匯入RDS您的 for Oracle 資料庫執行個體。

Oracle Data Pump 最佳實務

當您使用 Oracle Data Pump 將資料匯入RDS至 for Oracle 執行個體的 時,建議您採取下列最佳實務:

  • schematable 模式執行匯入,以匯入特定結構描述及物件。

  • 匯入的結構描述僅限於應用程式需要的結構描述。

  • 請勿匯入 full 模式或匯入系統維護元件的結構描述。

    由於 RDS for Oracle 不允許存取 SYSSYSDBA 管理使用者,因此這些動作可能會損壞 Oracle 資料字典,並影響資料庫的穩定性。

  • 當載入大量資料時,請執行下列作業:

    1. 將傾印檔案傳輸到 Oracle 資料庫執行個體RDS的目標。

    2. 拍攝您執行個體的資料庫快照。

    3. 測試匯入,以確認其是否成功。

    如果資料庫元件失效,您可以刪除資料庫執行個體,並由資料庫快照重新建立。還原的資料庫執行個體,包括您在製作資料庫快照時,暫存於資料庫執行個體的任何傾印檔案。

  • 請勿匯入使用 Oracle Data Pump 匯出參數 TRANSPORT_TABLESPACESTRANSPORTABLETRANSPORT_FULL_CHECK 建立的傾印檔案。RDS for Oracle 資料庫執行個體不支援匯入這些傾印檔案。

  • 請勿匯入包含 SYSSYSTEMRDSADMINRDSSECRDS_DATAGUARD 中之 Oracle Scheduler 物件的傾印檔案,且屬於下列類別:

    • 任務

    • 程式

    • Schedules

    • Chain

    • 規則

    • 評估內容

    • 規則集

    RDS for Oracle 資料庫執行個體不支援匯入這些傾印檔案。

  • 若要排除不支援的 Oracle Scheduler 物件,請在 Data Pump 匯出期間使用其他指令。如果您使用 DBMS_DATAPUMP,您可以在 DBMS_METADATA.START_JOB 之前新增一個額外的 METADATA_FILTER

    DBMS_DATAPUMP.METADATA_FILTER( v_hdnl, 'EXCLUDE_NAME_EXPR', q'[IN (SELECT NAME FROM SYS.OBJ$ WHERE TYPE# IN (66,67,74,79,59,62,46) AND OWNER# IN (SELECT USER# FROM SYS.USER$ WHERE NAME IN ('RDSADMIN','SYS','SYSTEM','RDS_DATAGUARD','RDSSEC') ) ) ]', 'PROCOBJ' );

    如果您使用 expdp,請建立包含 exclude 下列範例中所示之指令的參數檔案。然後透過 PARFILE=parameter_file 命令使用 expdp

    exclude=procobj:"IN (SELECT NAME FROM sys.OBJ$ WHERE TYPE# IN (66,67,74,79,59,62,46) AND OWNER# IN (SELECT USER# FROM SYS.USER$ WHERE NAME IN ('RDSADMIN','SYS','SYSTEM','RDS_DATAGUARD','RDSSEC') ) )"

以 Oracle Data Pump 及 Amazon S3 儲存貯體匯入資料

以下匯入程序使用 Oracle Data Pump 及 Amazon S3 儲存貯體。步驟如下:

  1. 使用 Oracle DBMS_DATAPUMP 套件匯出來源資料庫上的資料。

  2. 將傾印檔案放入 Amazon S3 儲存貯體。

  3. 從 Amazon S3 儲存貯體將傾印檔案下載至 RDS Oracle 資料庫執行個體目標上的DATA_PUMP_DIR目錄。

  4. 使用套件 將資料從複製的傾印檔案匯入 RDS for Oracle 資料庫執行個體DBMS_DATAPUMP

要求以 Oracle Data Pump 及 Amazon S3 儲存貯體匯入資料

此程序有以下要求:

  • 請確定 Amazon S3 儲存貯體可供檔案傳輸使用,且 Amazon S3 AWS 區域 儲存貯體與資料庫執行個體位於相同位置。如需指示說明,請參閱《Amazon Simple Storage Service 入門指南》中的建立儲存貯體

  • 您上傳到 Amazon S3 儲存貯體的物件必須為 5 TB 或更少。如需在 Amazon S3 中使用物件的詳細資訊,請參閱《Amazon Simple Storage Service 使用者指南》。

    注意

    如果您傾印檔案超過 5 TB,您可以使用平行選項執行 Oracle Data Pump 匯出。這項作業會將資料分散到多個傾印檔案,讓您不會超過個別檔案的 5 TB 限制。

  • 您必須遵循 中的指示,為 Amazon RDS整合準備 Amazon S3 儲存貯體設定 Oracle 與 Amazon S3 整合RDS的IAM許可

  • 您必須確定在來源執行個體和目前的資料庫執行個體上,有足夠的儲存空間可容納傾印檔案。

注意

此程序會將傾印檔案匯入 DATA_PUMP_DIR 目錄,這是在所有 Oracle 資料庫執行個體上預先設定好的目錄。此目錄和您的資料檔案位於相同的儲存磁碟區。您匯入傾印檔案時,現有 Oracle 資料檔案會使用更多空間。因此請確保資料庫執行個體能夠容納額外使用的空間。匯入的傾印檔案不會自動刪除或從 DATA_PUMP_DIR 目錄清除。若要移除匯入的傾印檔案,請使用 Oracle 網站上的 UTL_FILE.FREMOVE

步驟 1:將權限授予RDS適用於 Oracle 目標資料庫執行個體的 上的資料庫使用者

在此步驟中,您會建立要匯入資料的結構描述,並授與使用者必要的權限。

在 上建立使用者並授予 RDS Oracle 目標執行個體的必要權限
  1. 使用 SQL*Plus 或 Oracle SQL 開發人員以主要使用者身分登入要匯入資料的 RDS for Oracle 資料庫執行個體。如需連線至資料庫執行個體的詳細資訊,請參閱 連線至 RDS for Oracle 資料庫執行個體

  2. 匯入資料前,請先建立所需的資料表空間。如需詳細資訊,請參閱建立和調整資料表空間的大小

  3. 如果接收匯入資料的使用者帳戶不存在,請建立使用者帳戶並授予所需的許可和角色。如果要將資料匯入多個使用者結構描述,請建立每個使用者帳戶並授予所需的權限和角色。

    例如,下列SQL陳述式會建立新的使用者,並授予必要的許可和角色,以將資料匯入此使用者擁有的結構描述。請將此步驟及後續步驟的 schema_1 替換為結構描述名稱。

    CREATE USER schema_1 IDENTIFIED BY my_password; GRANT CREATE SESSION, RESOURCE TO schema_1; ALTER USER schema_1 QUOTA 100M ON users;
    注意

    指定此處所顯示提示以外的密碼,作為安全最佳實務。

    上述的陳述式會授予新使用者 CREATE SESSION 權限和 RESOURCE 角色。您可能會需要其他權限和角色,視您匯入的資料庫物件而定。

步驟 2:使用 DBMS_ 將資料匯出至傾印檔案DATAPUMP

若要建立傾印檔案,請使用 DBMS_DATAPUMP 套件。

將 Oracle 資料匯出到傾印檔案
  1. 使用 SQL Plus 或 Oracle SQL Developer 與管理使用者連線至 Oracle 資料庫執行個體RDS的來源。如果來源資料庫是RDS適用於 Oracle 資料庫執行個體的 ,請連線至 Amazon RDS主要使用者。

  2. 透過呼叫 DBMS_DATAPUMP 程序匯出資料。

    下列指令碼會匯出 SCHEMA_1 結構描述至 DATA_PUMP_DIR 目錄中名為 sample.dmp 的傾印檔案。以您要匯出之結構描述的名稱取代 SCHEMA_1

    DECLARE v_hdnl NUMBER; BEGIN v_hdnl := DBMS_DATAPUMP.OPEN( operation => 'EXPORT', job_mode => 'SCHEMA', job_name => null ); DBMS_DATAPUMP.ADD_FILE( handle => v_hdnl , filename => 'sample.dmp' , directory => 'DATA_PUMP_DIR', filetype => dbms_datapump.ku$_file_type_dump_file ); DBMS_DATAPUMP.ADD_FILE( handle => v_hdnl, filename => 'sample_exp.log', directory => 'DATA_PUMP_DIR' , filetype => dbms_datapump.ku$_file_type_log_file ); DBMS_DATAPUMP.METADATA_FILTER(v_hdnl,'SCHEMA_EXPR','IN (''SCHEMA_1'')'); DBMS_DATAPUMP.METADATA_FILTER( v_hdnl, 'EXCLUDE_NAME_EXPR', q'[IN (SELECT NAME FROM SYS.OBJ$ WHERE TYPE# IN (66,67,74,79,59,62,46) AND OWNER# IN (SELECT USER# FROM SYS.USER$ WHERE NAME IN ('RDSADMIN','SYS','SYSTEM','RDS_DATAGUARD','RDSSEC') ) ) ]', 'PROCOBJ' ); DBMS_DATAPUMP.START_JOB(v_hdnl); END; /
    注意

    Data Pump 會以非同步方式開始工作。如需有關監控 Data Pump 任務的詳細資訊,請參閱 Oracle 文件中的監控工作狀態

  3. (選用) 透過呼叫 rdsadmin.rds_file_util.read_text_file 程序檢視匯出日誌的內容。如需詳細資訊,請參閱讀取資料庫執行個體目錄中的檔案

步驟 3:將傾印檔案上傳至 Amazon S3 儲存貯體

使用 Amazon RDS 程序將傾印檔案rdsadmin.rdsadmin_s3_tasks.upload_to_s3複製到 Amazon S3 儲存貯體。以下範例將所有檔案從 DATA_PUMP_DIR 目錄上傳至名為 amzn-s3-demo-bucket 的 Amazon S3 儲存貯體。

SELECT rdsadmin.rdsadmin_s3_tasks.upload_to_s3( p_bucket_name => 'amzn-s3-demo-bucket', p_directory_name => 'DATA_PUMP_DIR') AS TASK_ID FROM DUAL;

SELECT 陳述式以 VARCHAR2 資料類型傳回任務 ID。如需詳細資訊,請參閱將檔案從 RDS for Oracle 資料庫執行個體上傳至 Amazon S3 儲存貯體

步驟 4:將傾印檔案從 Amazon S3 儲存貯體下載到您的目標資料庫執行個體

使用 Amazon RDS 程序 執行此步驟rdsadmin.rdsadmin_s3_tasks.download_from_s3。當您將文件下載到目錄時,如果目錄中已存在名稱相同的檔案,則程序 download_from_s3 會略過下載。若要從下載目錄移除檔案,請使用 Oracle 網站上找到的 UTL_FILE.FREMOVE

若要下載您的傾印檔案
  1. 啟動 SQL*Plus 或 Oracle SQL 開發人員,並以 Amazon RDS目標 Oracle 資料庫執行個體上的主機身分登入

  2. 使用 Amazon RDS 程序 下載傾印檔案rdsadmin.rdsadmin_s3_tasks.download_from_s3

    以下範例會從名為 amzn-s3-demo-bucket 的 Amazon S3 儲存貯體下載所有檔案至 DATA_PUMP_DIR 目錄。

    SELECT rdsadmin.rdsadmin_s3_tasks.download_from_s3( p_bucket_name => 'amzn-s3-demo-bucket', p_directory_name => 'DATA_PUMP_DIR') AS TASK_ID FROM DUAL;

    SELECT 陳述式以 VARCHAR2 資料類型傳回任務 ID。如需詳細資訊,請參閱將檔案從 Amazon S3 儲存貯體下載至 Oracle 資料庫執行個體

步驟 5:使用 DBMS_ 將傾印檔案匯入目標資料庫執行個體DATAPUMP

使用 將結構描述DBMS_DATAPUMP匯入RDS您的 for Oracle 資料庫執行個體。您可能需要額外選項,例如 METADATA_REMAP

將資料匯入目標資料庫執行個體
  1. 啟動 SQL*Plus 或 SQL Developer,並以主要使用者身分登入RDS您的 for Oracle 資料庫執行個體。

  2. 透過呼叫DBMS_DATAPUMP程序匯入資料。

    下列範例會匯入 SCHEMA_1sample_copied.dmp到目標資料庫執行個體的資料。

    DECLARE v_hdnl NUMBER; BEGIN v_hdnl := DBMS_DATAPUMP.OPEN( operation => 'IMPORT', job_mode => 'SCHEMA', job_name => null); DBMS_DATAPUMP.ADD_FILE( handle => v_hdnl, filename => 'sample_copied.dmp', directory => 'DATA_PUMP_DIR', filetype => dbms_datapump.ku$_file_type_dump_file); DBMS_DATAPUMP.ADD_FILE( handle => v_hdnl, filename => 'sample_imp.log', directory => 'DATA_PUMP_DIR', filetype => dbms_datapump.ku$_file_type_log_file); DBMS_DATAPUMP.METADATA_FILTER(v_hdnl,'SCHEMA_EXPR','IN (''SCHEMA_1'')'); DBMS_DATAPUMP.START_JOB(v_hdnl); END; /
    注意

    Data Pump 工作會以非同步的方式啟動。如需有關監控 Data Pump 任務的詳細資訊,請參閱 Oracle 文件中的監控工作狀態。您可以使用 rdsadmin.rds_file_util.read_text_file 程序來檢視匯入日誌的內容。如需詳細資訊,請參閱讀取資料庫執行個體目錄中的檔案

  3. 列出目標資料庫執行個體上的結構描述,以驗證資料匯入。

    例如,以下查詢會傳回 SCHEMA_1 的資料表數目。

    SELECT COUNT(*) FROM DBA_TABLES WHERE OWNER='SCHEMA_1';

步驟 6:清除

匯入資料後,您可以刪除不繼續保留的檔案。

若要移除不需要的檔案
  1. 啟動 SQL*Plus 或 SQL Developer,並以主要使用者身分登入RDS您的 for Oracle 資料庫執行個體。

  2. 使用以下命令列出 DATA_PUMP_DIR 中的檔案。

    SELECT * FROM TABLE(rdsadmin.rds_file_util.listdir('DATA_PUMP_DIR')) ORDER BY MTIME;
  3. 使用以下命令刪除 DATA_PUMP_DIR 中不再需要的檔案。

    EXEC UTL_FILE.FREMOVE('DATA_PUMP_DIR','filename');

    例如以下命令會刪除名為 sample_copied.dmp 的檔案。

    EXEC UTL_FILE.FREMOVE('DATA_PUMP_DIR','sample_copied.dmp');

下列匯入程序使用 Oracle Data Pump 和 Oracle DBMS_FILE_TRANSFER 套件。步驟如下:

  1. 連線至來源 Oracle 資料庫,該資料庫可以是內部部署資料庫、Amazon EC2執行個體或RDS適用於 Oracle 資料庫執行個體的 。

  2. 使用 DBMS_DATAPUMP 套件匯出資料。

  3. 使用 將傾印檔案從 Oracle 資料庫DBMS_FILE_TRANSFER.PUT_FILE複製到使用資料庫連結連線RDS的 Oracle 資料庫執行個體目標上的DATA_PUMP_DIR目錄。

  4. 使用 DBMS_DATAPUMP套件,將資料從複製的傾印檔案匯入RDS適用於 Oracle 資料庫執行個體的 。

使用 Oracle Data Pump 及 DBMS_FILE_TRANSFER 套件的匯入程序具有下列步驟。

匯入 Oracle Data Pump 及資料庫連結的要求

此程序有以下要求:

  • 您必須具有在 DBMS_FILE_TRANSFER 上和 DBMS_DATAPUMP 套件的執行權限。

  • 您必須有寫入來源資料庫執行個體 DATA_PUMP_DIR 目錄的權限。

  • 您必須確定在來源執行個體和目前的資料庫執行個體上,有足夠的儲存空間可容納傾印檔案。

注意

此程序會將傾印檔案匯入 DATA_PUMP_DIR 目錄,這是在所有 Oracle 資料庫執行個體上預先設定好的目錄。此目錄和您的資料檔案位於相同的儲存磁碟區。您匯入傾印檔案時,現有 Oracle 資料檔案會使用更多空間。因此請確保資料庫執行個體能夠容納額外使用的空間。匯入的傾印檔案不會自動刪除或從 DATA_PUMP_DIR 目錄清除。若要移除匯入的傾印檔案,請使用 Oracle 網站上的 UTL_FILE.。FREMOVE

步驟 1:將權限授予RDS適用於 Oracle 目標資料庫執行個體的 上的使用者

若要在 RDS for Oracle 目標資料庫執行個體的 上將權限授予使用者,請執行下列步驟:

  1. 使用 SQL Plus 或 Oracle SQL Developer 連線至您要將資料匯入其中RDS的 for Oracle 資料庫執行個體。以 Amazon RDS主要使用者身分連線。如需連線至資料庫執行個體的詳細資訊,請參閱 連線至 RDS for Oracle 資料庫執行個體

  2. 匯入資料前,請先建立所需的資料表空間。如需更多詳細資訊,請參閱 建立和調整資料表空間的大小

  3. 如果接受匯入資料的使用者帳戶不存在,請建立使用者帳戶並授予所需的許可和角色。如果要將資料匯入多個使用者結構描述,請建立每個使用者帳戶並授予所需的權限和角色。

    例如,下列命令會建立新的名為 的使用者 schema_1 和 授予必要的許可和角色,以將資料匯入此使用者的結構描述。

    CREATE USER schema_1 IDENTIFIED BY my-password; GRANT CREATE SESSION, RESOURCE TO schema_1; ALTER USER schema_1 QUOTA 100M ON users;
    注意

    指定此處所顯示提示以外的密碼,作為安全最佳實務。

    上述範例向新使用者授予 CREATE SESSION 權限及 RESOURCE 角色。您可能會需要其他權限和角色,視您匯入的資料庫物件而定。

    注意

    請將此步驟及後續步驟的 schema_1 替換為結構描述名稱。

步驟 2:向來源資料庫的使用者授予權限

使用 SQL*Plus 或 Oracle SQL 開發人員連線至包含要匯入資料的RDS適用於 Oracle 資料庫執行個體。如有需要,建立使用者帳戶並授予必需的許可。

注意

如果來源資料庫是 Amazon RDS執行個體,您可以略過此步驟。您可以使用 Amazon RDS主要使用者帳戶來執行匯出。

以下命令會建立新的使用者並授予必需的許可。

CREATE USER export_user IDENTIFIED BY my-password; GRANT CREATE SESSION, CREATE TABLE, CREATE DATABASE LINK TO export_user; ALTER USER export_user QUOTA 100M ON users; GRANT READ, WRITE ON DIRECTORY data_pump_dir TO export_user; GRANT SELECT_CATALOG_ROLE TO export_user; GRANT EXECUTE ON DBMS_DATAPUMP TO export_user; GRANT EXECUTE ON DBMS_FILE_TRANSFER TO export_user;
注意

指定此處所顯示提示以外的密碼,作為安全最佳實務。

步驟 3:使用 DBMS_ 建立傾印檔案DATAPUMP

若要建立傾印檔案,請執行下列步驟:

  1. 使用 SQL*Plus 或 Oracle SQL 開發人員,透過管理使用者或您在步驟 2 中建立的使用者連線到來源 Oracle 執行個體。如果來源資料庫是 Amazon RDS for Oracle 資料庫執行個體,請與 Amazon RDS主要使用者連線。

  2. 使用 Oracle Data Pump 公用程式建立傾印檔案。

    以下指令碼會在 DATA_PUMP_DIR 目錄中建立名為 sample.dmp 的傾印檔案。

    DECLARE v_hdnl NUMBER; BEGIN v_hdnl := DBMS_DATAPUMP.OPEN( operation => 'EXPORT' , job_mode => 'SCHEMA' , job_name => null ); DBMS_DATAPUMP.ADD_FILE( handle => v_hdnl, filename => 'sample.dmp' , directory => 'DATA_PUMP_DIR' , filetype => dbms_datapump.ku$_file_type_dump_file ); DBMS_DATAPUMP.ADD_FILE( handle => v_hdnl , filename => 'sample_exp.log' , directory => 'DATA_PUMP_DIR' , filetype => dbms_datapump.ku$_file_type_log_file ); DBMS_DATAPUMP.METADATA_FILTER( v_hdnl , 'SCHEMA_EXPR' , 'IN (''SCHEMA_1'')' ); DBMS_DATAPUMP.METADATA_FILTER( v_hdnl, 'EXCLUDE_NAME_EXPR', q'[IN (SELECT NAME FROM sys.OBJ$ WHERE TYPE# IN (66,67,74,79,59,62,46) AND OWNER# IN (SELECT USER# FROM SYS.USER$ WHERE NAME IN ('RDSADMIN','SYS','SYSTEM','RDS_DATAGUARD','RDSSEC') ) ) ]', 'PROCOBJ' ); DBMS_DATAPUMP.START_JOB(v_hdnl); END; /
    注意

    Data Pump 工作會以非同步的方式啟動。如需有關監控 Data Pump 任務的詳細資訊,請參閱 Oracle 文件中的監控工作狀態。您可以使用 rdsadmin.rds_file_util.read_text_file 程序檢視匯出日誌的內容。如需更多詳細資訊,請參閱 讀取資料庫執行個體目錄中的檔案

步驟 4:建立與目標資料庫執行個體的資料庫連結

在來源資料庫執行個體與目標資料庫執行個體之間建立資料庫連結。您的本機 Oracle 執行個體必須可以和資料庫執行個體網路連線,才能建立資料庫連結以及傳輸匯出傾印檔案。

請以前一步驟的相同使用者身分執行此步驟。

如果您要在相同VPC或對等 內的兩個資料庫執行個體之間建立資料庫連結VPCs,則兩個資料庫執行個體之間應具有有效的路由。這兩個資料庫執行個體的安全群組,皆必須允許輸入和輸出到其他資料庫執行個體。安全群組傳入和傳出規則可以參考來自相同 VPC 或對等 的安全群組VPC。如需詳細資訊,請參閱調整資料庫連結以搭配 中的資料庫執行個體使用 VPC

下列命令會建立名為 的資料庫連結to_rds,以連線至目標資料庫執行個體的 Amazon RDS主要使用者。

CREATE DATABASE LINK to_rds CONNECT TO <master_user_account> IDENTIFIED BY <password> USING '(DESCRIPTION=(ADDRESS=(PROTOCOL=TCP)(HOST=<dns or ip address of remote db>) (PORT=<listener port>))(CONNECT_DATA=(SID=<remote SID>)))';

步驟 5:使用 DBMS_FILE_ 將匯出的傾印檔案複製到目標資料庫執行個體TRANSFER

使用 DBMS_FILE_TRANSFER,將傾印檔案從來源資料庫執行個體複製到目標資料庫執行個體。以下指令碼會將名為 sample.dmp 的傾印檔案,從來源執行個體複製到名為 to_rds 的目標資料庫連結 (在先前步驟中建立)。

BEGIN DBMS_FILE_TRANSFER.PUT_FILE( source_directory_object => 'DATA_PUMP_DIR', source_file_name => 'sample.dmp', destination_directory_object => 'DATA_PUMP_DIR', destination_file_name => 'sample_copied.dmp', destination_database => 'to_rds' ); END; /

步驟 6:使用 DBMS_ 將資料檔案匯入目標資料庫執行個體DATAPUMP

使用 Oracle Data Pump 匯入資料庫執行個體上的結構描述。可能需要其他選項,例如 METADATA_REMAP。

使用 Amazon RDS主要使用者帳戶連線至資料庫執行個體,以執行匯入。

DECLARE v_hdnl NUMBER; BEGIN v_hdnl := DBMS_DATAPUMP.OPEN( operation => 'IMPORT', job_mode => 'SCHEMA', job_name => null); DBMS_DATAPUMP.ADD_FILE( handle => v_hdnl, filename => 'sample_copied.dmp', directory => 'DATA_PUMP_DIR', filetype => dbms_datapump.ku$_file_type_dump_file ); DBMS_DATAPUMP.ADD_FILE( handle => v_hdnl, filename => 'sample_imp.log', directory => 'DATA_PUMP_DIR', filetype => dbms_datapump.ku$_file_type_log_file); DBMS_DATAPUMP.METADATA_FILTER(v_hdnl,'SCHEMA_EXPR','IN (''SCHEMA_1'')'); DBMS_DATAPUMP.START_JOB(v_hdnl); END; /
注意

Data Pump 工作會以非同步的方式啟動。如需有關監控 Data Pump 任務的詳細資訊,請參閱 Oracle 文件中的監控工作狀態。您可以使用 rdsadmin.rds_file_util.read_text_file 程序來檢視匯入日誌的內容。如需更多詳細資訊,請參閱 讀取資料庫執行個體目錄中的檔案

您可以檢視資料庫執行個體上的使用者資料表,以確認資料的匯入。例如,以下查詢會傳回 schema_1 的資料表數目。

SELECT COUNT(*) FROM DBA_TABLES WHERE OWNER='SCHEMA_1';

步驟 7:清理

匯入資料後,您可以刪除不繼續保留的檔案。您可以使用以下命令列出 DATA_PUMP_DIR 中的檔案。

SELECT * FROM TABLE(rdsadmin.rds_file_util.listdir('DATA_PUMP_DIR')) ORDER BY MTIME;

以下命令可用來刪除 DATA_PUMP_DIR 中不再需要的檔案。

EXEC UTL_FILE.FREMOVE('DATA_PUMP_DIR','<file name>');

例如以下命令會刪除名為 "sample_copied.dmp" 的檔案。

EXEC UTL_FILE.FREMOVE('DATA_PUMP_DIR','sample_copied.dmp');