一 關於expdp和impdp 使用EXPDP和IMPDP時應該注意的事項:
EXP和IMP是客戶端工具程序,它們既能夠在客戶端使用,也能夠在服務端使用。
EXPDP和IMPDP是服務端的工具程序,他們只能在ORACLE服務端使用,不能在客戶端使用。
IMP只適用於EXP導出的文件,不適用於EXPDP導出文件;IMPDP只適用於EXPDP導出的文件,而不適用於EXP導出文件。
expdp或impdp命令時,可暫不指出用戶名/密碼@實例名 as 身份,而後根據提示再輸入,如:
expdp schemas=scott dumpfile=expdp.dmp DIRECTORY=dpdata1;
1、建立邏輯目錄,該命令不會在操做系統建立真正的目錄,最好以system等管理員建立。
create directory dpdata1 as 'd:\test\dump';
2、查看管理理員目錄(同時查看操做系統是否存在,由於Oracle並不關心該目錄是否存在,若是不存在,則出錯)
select * from dba_directories;
3、給scott用戶賦予在指定目錄的操做權限,最好以system等管理員賦予。
grant read,write on directory dpdata1 to scott;
4、導出數據
1)按用戶導
expdp scott/tiger@orcl schemas=scott dumpfile=expdp.dmp DIRECTORY=dpdata1;
2)並行進程parallel
expdp scott/tiger@orcl directory=dpdata1 dumpfile=scott3.dmp parallel=40 job_name=scott3
3)按表名導
expdp scott/tiger@orcl TABLES=emp,dept dumpfile=expdp.dmp DIRECTORY=dpdata1;
4)按查詢條件導
expdp scott/tiger@orcl directory=dpdata1 dumpfile=expdp.dmp Tables=emp query='WHERE deptno=20';
5)按表空間導
expdp system/manager DIRECTORY=dpdata1 DUMPFILE=tablespace.dmp TABLESPACES=temp,example;
6)導整個數據庫
expdp system/manager DIRECTORY=dpdata1 DUMPFILE=full.dmp FULL=y;
5、還原數據
1)導到指定用戶下
impdp scott/tiger DIRECTORY=dpdata1 DUMPFILE=expdp.dmp SCHEMAS=scott;
2)改變表的owner
impdp system/manager DIRECTORY=dpdata1 DUMPFILE=expdp.dmp TABLES=scott.dept REMAP_SCHEMA=scott:system;
3)導入表空間
impdp system/manager DIRECTORY=dpdata1 DUMPFILE=tablespace.dmp TABLESPACES=example;
4)導入數據庫
impdb system/manager DIRECTORY=dump_dir DUMPFILE=full.dmp FULL=y;
5)追加數據
impdp system/manager DIRECTORY=dpdata1 DUMPFILE=expdp.dmp SCHEMAS=system TABLE_EXISTS_ACTION
二 附加說明 並行操做(PARALLEL)
您能夠經過 PARALLEL 參數爲導出使用一個以上的線程來顯著地加速做業。每一個線程建立一個單獨的轉儲文件,所以參數 dumpfile 應當擁有和並行度同樣多的項目。您能夠指定通配符做爲文件名,而不是顯式地輸入各個文件名,例如:
expdp ananda/abc123 tables=CASES directory=DPDATA1 dumpfile=expCASES_%U.dmp parallel=4 job_name=Cases_Export
注意:dumpfile 參數擁有一個通配符 %U,它指示文件將按須要建立,格式將爲expCASES_nn.dmp,其中nn 從 01 開始,而後按須要向上增長。
在並行模式下,狀態屏幕將顯示四個工做進程。(在默認模式下,只有一個進程是可見的)全部的工做進程同步取出數據,並在狀態屏幕上顯示它們的進度。
分離訪問數據文件和轉儲目錄文件系統的輸入/輸出通道是很重要的。不然,與維護 Data Pump 做業相關的開銷可能超過並行線程的效益,並所以而下降性能。並行方式只有在表的數量多於並行值而且表很大時纔是有效的。
數據庫監控
您還能夠從數據庫視圖得到關於運行的 Data Pump 做業的更多信息。監控做業的主視圖是 DBA_DATAPUMP_JOBS,它將告訴您在做業上有多少個工做進程(列 DEGREE)在工做。
另外一個重要的視圖是 DBA_DATAPUMP_SESSIONS,當它與上述視圖和 V$SESSION 結合時將給出主前臺進程的會話 SID。
select sid, serial# from v$session s, dba_datapump_sessions d where s.saddr = d.saddr;
這條指令顯示前臺進程的會話。更多有用的信息能夠從警報日誌中得到。當進程啓動時,MCP 和工做進程在警報日誌中顯示以下:
kupprdp:master process DM00 started with pid=23, OS id=20530 to execute - SYS.KUPM$MCP.MAIN('CASES_EXPORT', 'ANANDA'); kupprdp:worker process DW01 started with worker id=1, pid=24, OS id=20532 to execute - SYS.KUPW$WORKER.MAIN('CASES_EXPORT', 'ANANDA'); kupprdp:worker process DW03 started with worker id=2, pid=25, OS id=20534 to execute - SYS.KUPW$WORKER.MAIN('CASES_EXPORT', 'ANANDA');
它顯示爲數據泵操做啓動的會話的 PID。您能夠用如下查詢找到實際的 SID:
select sid, program from v$session where paddr in (select addr from v$process where pid in (23,24,25));
PROGRAM 列將對應警報日誌文件中的名稱顯示進程 DM (爲主進程)或 DW (爲工做進程)。若是一個工做進程使用了並行查詢,好比說 SID 23,您能夠在視圖 V$PX_SESSION 中看到它,並把它找出來。它將爲您顯示從 SID 23 表明的工做進程中運行的全部並行查詢會話:
select sid from v$px_session where qcsid = 23;
從視圖 V$SESSION_LONGOPS 中能夠得到其它的有用信息來預測完成做業將花費的時間。
select sid, serial#, sofar, totalwork from v$session_longops where opname = 'CASES_EXPORT' and sofar != totalwork;
列 totalwork 顯示總工做量,該列的 sofar 數量被加和到當前的時刻 — 於是您能夠用它來估計還要花多長時間。
三 oracle 10g 和11g的互相導入和導出 1) 能夠用10g的client鏈接11個導出11g的數據庫,便可導入10g 2)用expdp,impdp,如:
在11g服務器上,使用expdp命令備份數據
EXPDP USERID='SYS/cuc2009@cuc as sysdba' schemas=sybj directory=DATA_PUMP_DIR dumpfile=aa.dmp logfile=aa.log version=10.2.0.1.0
在10g服務器上,使用impdp命令恢復數據
準備工做:1.建庫2.建表空間3.建用戶並受權4.將aa.dmp拷貝到10g的dpdump目錄下
IMPDP USERID='SYS/cuc2009@cucf as sysdba' schemas=sybj directory=DATA_PUMP_DIR dumpfile=aa.dmp logfile=aa.log version=10.2.0.1.0數據庫