12c推出了可插拔數據庫,在一個容器cdb中以多租戶的形式同時存在多個數據庫pdb。在爲pdb作數據泵導入導出時和傳統的數據庫有少量不一樣。sql
1,須要爲pdb添加tansnames數據庫
2,導入導出時須要在userid參數內指定其tansnames的值,好比 userid=user/pwd@tnsnamebash
數據泵導出session
[oracle@test admin]$ echo $ORACLE_SID [oracle@test admin]orcl
登陸cdb,查看pdb,oracle
SQL> show con_name CON_NAME ------------------------------ CDB$ROOT SQL> show pdbs CON_ID CON_NAME OPEN MODE RESTRICTED ---------- ------------------------------ ---------- ---------- PDB$SEED READ ONLY NO PDBORCL MOUNTED SQL> alter pluggable database all open; Pluggable database altered. SQL> show pdbs CON_ID CON_NAME OPEN MODE RESTRICTED ---------- ------------------------------ ---------- ---------- PDB$SEED READ ONLY NO PDBORCL READ WRITE NO
切換到pdborclapp
SQL> alter session set container=pdborcl; Session altered. SQL>
SQL> select owner, table_name from dba_tables where owner='SCOTT'; OWNER TABLE_NAME ------------------------------ ---------------------------------------- SCOTT SALGRADE SCOTT BONUS SCOTT EMP SCOTT DEPT
SQL> grant dba to dp identified by dp; Grant succeeded.
SQL> create or replace directory dp_dir as '/home/oracle'; Directory created. SQL> exit
(若是是dba權限的這一步能夠省略,爲了試驗的完整性這裏保留)ide
SQL> grant read,write on directory dp_dir to dp; Grant succeeded.
[oracle@xqzt admin]$ pwd /data/app/oracle/product/12.1.0/dbhome_1/network/admin [oracle@xqzt admin]$ cat tnsnames.ora # tnsnames.ora Network Configuration File: /data/app/oracle/product/12.1.0/dbhome_1/network/admin/tnsnames.ora # Generated by Oracle configuration tools. ORCL = (DESCRIPTION = (ADDRESS = (PROTOCOL = TCP)(HOST = xqzt)(PORT = 1521)) (CONNECT_DATA = (SERVER = DEDICATED) (SERVICE_NAME = orcl) ) ) PDBORCL = (DESCRIPTION = (ADDRESS = (PROTOCOL = TCP)(HOST = xqzt)(PORT = 1521)) (CONNECT_DATA = (SERVER = DEDICATED) (SERVICE_NAME =pdborcl) ) )
[oracle@xqzt admin]$ tnsping pdborcl TNS Ping Utility for Linux: Version 12.1.0.2.0 - Production on 10-DEC-2015 09:10:34 Copyright (c) 1997, 2014, Oracle. All rights reserved. Used parameter files: /data/app/oracle/product/12.1.0/dbhome_1/network/admin/sqlnet.ora Used TNSNAMES adapter to resolve the alias Attempting to contact (DESCRIPTION = (ADDRESS = (PROTOCOL = TCP)(HOST = xqzt)(PORT = 1521)) (CONNECT_DATA = (SERVER = DEDICATED) (SERVICE_NAME =pdborcl))) OK (0 msec)
用戶名密碼爲dp/dp,而且經過tnsnames指向pdborcl測試
數據泵目錄爲:dp_dir, OS路徑是/home/oraclespa
導出文件爲:/home/oracle/scott_pdborcl.dmp日誌
導出日誌爲:/home/oracle/scott_pdborcl.log
導出模式爲scheme,也能夠理解爲用戶:scott
[oracle@xqzt ~]$ expdp dp/dp@pdborcl directory=dp_dir dumpfile=scott_pdborcl.dmp logfile=scott_pdborcl.log schemas=scott Export: Release 12.1.0.2.0 - Production on Thu Dec 10 09:32:05 2015Copyright (c) 1982, 2014, Oracle and/or its affiliates. All rights reserved. Connected to: Oracle Database 12c Enterprise Edition Release 12.1.0.2.0 - 64bit Production With the Partitioning, OLAP, Advanced Analytics and Real Application Testing options Starting "DP"."SYS_EXPORT_SCHEMA_01": dp/********@pdborcl directory=dp_dir dumpfile=scott_pdborcl.dmp logfile=scott_pdborcl.log schemas=scott Estimate in progress using BLOCKS method... Processing object type SCHEMA_EXPORT/TABLE/TABLE_DATA Total estimation using BLOCKS method: 192 KB Processing object type SCHEMA_EXPORT/USER Processing object type SCHEMA_EXPORT/SYSTEM_GRANT Processing object type SCHEMA_EXPORT/ROLE_GRANT Processing object type SCHEMA_EXPORT/DEFAULT_ROLE Processing object type SCHEMA_EXPORT/PRE_SCHEMA/PROCACT_SCHEMA Processing object type SCHEMA_EXPORT/TABLE/TABLE Processing object type SCHEMA_EXPORT/TABLE/INDEX/INDEX Processing object type SCHEMA_EXPORT/TABLE/CONSTRAINT/CONSTRAINT Processing object type SCHEMA_EXPORT/TABLE/INDEX/STATISTICS/INDEX_STATISTICS Processing object type SCHEMA_EXPORT/TABLE/CONSTRAINT/REF_CONSTRAINT Processing object type SCHEMA_EXPORT/TABLE/STATISTICS/TABLE_STATISTICS Processing object type SCHEMA_EXPORT/STATISTICS/MARKER . . exported "SCOTT"."DEPT" 6.023 KB 4 rows . . exported "SCOTT"."EMP" 8.773 KB 14 rows . . exported "SCOTT"."SALGRADE" 6.023 KB 10 rows . . exported "SCOTT"."BONUS" 0 KB 0 rows Master table "DP"."SYS_EXPORT_SCHEMA_01" successfully loaded/unloaded ****************************************************************************** Dump file set for DP.SYS_EXPORT_SCHEMA_01 is: /home/oracle/scott_pdborcl.dmp Job "DP"."SYS_EXPORT_SCHEMA_01" successfully completed at Thu Dec 10 09:32:29 2015 elapsed 0 00:00:21 [oracle@xqzt ~]$
[oracle@xqzt ~]$ ls -l scott_pdborcl.dmp scott_pdborcl.log -rw-r----- 1 oracle oinstall 356352 12月 10 09:32 scott_pdborcl.dmp -rw-r--r-- 1 oracle oinstall 1960 12月 10 09:32 scott_pdborcl.log
SQL> select count(*) from scott.DEPT; COUNT(*) ---------- SQL> drop user scott cascade ; User dropped. SQL>
此時訪問該用戶的表已經不存在了
SQL> select count(*) from scott.DEPT; select count(*) from scott.DEPT *ERROR at line 1: ORA-00942: table or view does not exist
[oracle@xqzt ~]$ impdp dp/dp@pdborcl directory=dp_dir dumpfile=scott_pdborcl.dmp logfile=scott_pdborcl_imp.log schemas=scott Import: Release 12.1.0.2.0 - Production on Thu Dec 10 09:39:02 2015Copyright (c) 1982, 2014, Oracle and/or its affiliates. All rights reserved. Connected to: Oracle Database 12c Enterprise Edition Release 12.1.0.2.0 - 64bit Production With the Partitioning, OLAP, Advanced Analytics and Real Application Testing options Master table "DP"."SYS_IMPORT_SCHEMA_01" successfully loaded/unloaded Starting "DP"."SYS_IMPORT_SCHEMA_01": dp/********@pdborcl directory=dp_dir dumpfile=scott_pdborcl.dmp logfile=scott_pdborcl_imp.log schemas=scott Processing object type SCHEMA_EXPORT/USER Processing object type SCHEMA_EXPORT/SYSTEM_GRANT Processing object type SCHEMA_EXPORT/ROLE_GRANT Processing object type SCHEMA_EXPORT/DEFAULT_ROLE Processing object type SCHEMA_EXPORT/PRE_SCHEMA/PROCACT_SCHEMA Processing object type SCHEMA_EXPORT/TABLE/TABLE Processing object type SCHEMA_EXPORT/TABLE/TABLE_DATA . . imported "SCOTT"."DEPT" 6.023 KB 4 rows . . imported "SCOTT"."EMP" 8.773 KB 14 rows . . imported "SCOTT"."SALGRADE" 6.023 KB 10 rows . . imported "SCOTT"."BONUS" 0 KB 0 rows Processing object type SCHEMA_EXPORT/TABLE/INDEX/INDEX Processing object type SCHEMA_EXPORT/TABLE/CONSTRAINT/CONSTRAINT Processing object type SCHEMA_EXPORT/TABLE/INDEX/STATISTICS/INDEX_STATISTICS Processing object type SCHEMA_EXPORT/TABLE/CONSTRAINT/REF_CONSTRAINT Processing object type SCHEMA_EXPORT/TABLE/STATISTICS/TABLE_STATISTICS Processing object type SCHEMA_EXPORT/STATISTICS/MARKER Job "DP"."SYS_IMPORT_SCHEMA_01" successfully completed at Thu Dec 10 09:39:06 2015 elapsed 0 00:00:04 [oracle@xqzt ~]$
1三、 測試導入結果
SQL> select count(*) from scott.DEPT; COUNT(*) ---------- 4
導入成功!