溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

Oracle常用導(dǎo)出導(dǎo)出命令及性能效率對比

發(fā)布時間:2020-06-26 02:04:19 來源:網(wǎng)絡(luò) 閱讀:1747 作者:pizibaidu 欄目:關(guān)系型數(shù)據(jù)庫

 

說明

Oracle導(dǎo)入導(dǎo)出命令主要有EXPDP和IMPDP、EXP和IMP,區(qū)別如下:EXP和IMP是客戶端工具程序,它們既可以在客戶端使用,也可以在服務(wù)端使用。EXPDP和IMPDP是服務(wù)端的工具程序,他們只能在ORACLE服務(wù)端使用,不能在客戶端使用。IMP只適用于EXP導(dǎo)出的文件,不適用于EXPDP導(dǎo)出文件;IMPDP只適用于EXPDP導(dǎo)出的文件,而不適用于EXP導(dǎo)出文件。expdp或impdp命令時,可暫不指出用戶名/密碼@實例名as 身份,然后根據(jù)提示再輸入,如:expdp schemas=scott dumpfile=test.dmp DIRECTORY=testdata; 兩個命令都直接在CMD命令中執(zhí)行。

 

一 、EXPDP和IMPDP命令

1.1、創(chuàng)建邏輯目錄,該命令不會在操作系統(tǒng)創(chuàng)建真正的目錄,最好以system等管理員創(chuàng)建。

 create directory testdata  as 'd:\test\dump';


查看管理理員目錄(同時查看操作系統(tǒng)是否存在,因為Oracle并不關(guān)心該目錄是否存在,如果不存在,則出錯)

select * from dba_directories;


給scott用戶賦予在指定目錄的操作權(quán)限,最好以system等管理員賦予。

grant read,write on directory testdata to scott;

 

1.2、導(dǎo)出數(shù)據(jù)

1)按用戶導(dǎo)

expdp scott/tiger@orcl schemas=scott dumpfile=test.dmp DIRECTORY=testdata ;

2)并行進程parallel

expdp scott/tiger@orcl directory=testdata  dumpfile=test.dmp parallel=40 job_name=testjob

3)按表名導(dǎo)

expdp scott/tiger@orcl TABLES=emp,dept dumpfile=test.dmp DIRECTORY=testdata ;

4)按查詢條件導(dǎo)

expdp scott/tiger@orcl directory=testdata dumpfile=test.dmp Tables=emp query='WHERE deptno=20';

5)按表空間導(dǎo)

expdp system/manager DIRECTORY=testdata DUMPFILE=test.dmp TABLESPACES=temp,example;

6)導(dǎo)整個數(shù)據(jù)庫

expdp system/manager DIRECTORY=testdata DUMPFILE=full.dmp FULL=y;

 

1.3、導(dǎo)入數(shù)據(jù)

1)導(dǎo)到指定用戶下

impdp scott/tiger DIRECTORY=testdata DUMPFILE=test.dmp SCHEMAS=scott;

2)改變表的owner

impdp system/manager DIRECTORY=testdata DUMPFILE=test.dmp TABLES=scott.dept REMAP_SCHEMA=scott:system;

3)導(dǎo)入表空間

impdp system/manager DIRECTORY=testdata DUMPFILE=test.dmp TABLESPACES=example;

4)導(dǎo)入數(shù)據(jù)庫

impdb system/manager DIRECTORY=testdata DUMPFILE=full.dmp FULL=y;

5)追加數(shù)據(jù)

impdp system/manager DIRECTORY=testdata DUMPFILE=test.dmp SCHEMAS=system TABLE_EXISTS_ACTION

 

二、EXP和IMP命令

2.1、EXP命令

有三種主要的方式(完全、用戶、表)    
1、完全:    
EXP SYSTEM/MANAGER BUFFER=64000 file=D:\all.dmp log=D:\all.log FULL=Y    
如果要執(zhí)行完全導(dǎo)出,必須具有特殊的權(quán)限


2、用戶模式:    
EXP test/test BUFFER=64000 FILE=D:\test.DMP log=D:\test.log OWNER=test

這樣用戶test的所有對象被輸出到文件中。


3、表模式:    
EXP test/test    BUFFER=64000 FILE=D:\test.DMP log=D:\test.log OWNER=test TABLES=(test)    這樣用戶test的表test就被導(dǎo)出


2.2、IMP命令   
具有三種模式(完全、用戶、表)    
1、完全:    
 IMP SYSTEM/MANAGER BUFFER=64000 FILE=D:\FULL.DMP log=D:\impfull.log FULL=Y


2、用戶模式:    
 IMP test/test    BUFFER=64000 FILE=D:\test.DMP log=D:\imptest.log FROMUSER=test TOUSER=test    
 這樣用戶test的所有對象被導(dǎo)入到文件中。必須指定FROMUSER、TOUSER參數(shù),這樣才能導(dǎo)入數(shù)據(jù)。


3、表模式:    
 EXP test/test    BUFFER=64000 FILE=D:\test.DMP log=D:\imptest.log OWNER=test TABLES=(test)    
這樣用戶test的表test就被導(dǎo)入。

 

2.3  關(guān)于參數(shù)ignore=y

如果用了參數(shù)ignore=y, 會把exp文件內(nèi)的數(shù)據(jù)內(nèi)容導(dǎo)入;如果表有唯一關(guān)鍵字的約束條件, 不合條件將不被導(dǎo)入;如果表沒有唯一關(guān)鍵字的約束條件, 將引起記錄重復(fù)

解釋:

當(dāng)要導(dǎo)入數(shù)據(jù)庫中已經(jīng)存在了某個表(test),如果該表沒有唯一性約束,那么在導(dǎo)入時加參數(shù)ignore=y,則會把數(shù)據(jù)完全導(dǎo)入到表中,而且不報錯。  
當(dāng)表已經(jīng)存在了唯一性約束,特別是主鍵的約束,那么在導(dǎo)入時,只導(dǎo)入主鍵中不存在的記錄. 導(dǎo)入過程中會有警告.    
利用這個原則可以做一個增量導(dǎo)入.

三、性能效率對比(直接引用別人的文章)

3.1 導(dǎo)出性能對比

EXP常規(guī)模式、EXP直接路徑模式和EXPDP三種方式導(dǎo)出的性能對比

1) 首先是EXP的常規(guī)路徑導(dǎo)出:

exp zhejiang/zhejiang file=/data1/zj_regular.dmp buffer=20480000

常規(guī)EXP導(dǎo)出方式執(zhí)行了1小時24分鐘。

 

2) 直接路徑導(dǎo)出方式:

exp zhejiang/zhejiang file=/data1/zj_direct.dmp buffer=20480000

recordlength=65535 direct=y

直接路徑導(dǎo)入用時18分鐘,比常規(guī)路徑導(dǎo)出速度有一個明顯的提高。

 

3) 數(shù)據(jù)泵的導(dǎo)出速度。

expdp zhejiang/zhejiang dumpfile=zj_datapump.dp directory=d_test schemas=zhejiang

數(shù)據(jù)泵的導(dǎo)出時間僅用了14分鐘,比直接路徑導(dǎo)入方式還快了20%多。而且觀察三個導(dǎo)出文件的大小可以發(fā)現(xiàn),導(dǎo)出速度越快對應(yīng)的文件也越小,其中數(shù)據(jù)泵的導(dǎo)出方式得到的文件要比EXP方式小將近1.5G。

 

3.2 導(dǎo)入性能對比

IMP和IMPDP導(dǎo)入性能對比

1) IMP的導(dǎo)入速度:

imp zhejiang/zhejiang file=/data1/zj_regular.dmp full=y buffer=20480000 log=/data1/zj_regular.log

IMP導(dǎo)入花費了3小時17分鐘,

 

2) IMPdp的導(dǎo)入速度:

impdp zhejiang/zhejiang DUMPFILE=zj_datapump.dp DIRECTORY=d_test FULL=y LOGFILE=zj_datapump.log

數(shù)據(jù)泵的導(dǎo)入操作居然花了3個小時8分鐘的時間,和IMP的導(dǎo)入速度十分接近,看來并非所有情況下都像Oracle描述的那樣,數(shù)據(jù)泵的導(dǎo)入比普通導(dǎo)入效率有大幅度的提高。

 

測試中發(fā)現(xiàn)IMPDP的導(dǎo)入速度和IMP導(dǎo)入速度相差無幾。而Oracle在介紹數(shù)據(jù)泵的時候,提到IMPDP的導(dǎo)入速度最高是IMP的10倍。不過好在IMPDP還是可以優(yōu)化調(diào)整的,那就是通過設(shè)置PARALLEL來提高IMPDP的并行度。

首先還是看一下CPU的數(shù)量:

SQL> show parameter cpu

由于數(shù)據(jù)庫服務(wù)器的CPU個數(shù)為2,下面嘗試設(shè)置PARALLEL為2來進行導(dǎo)入

impdp zhejiang/zhejiang DUMPFILE=zj_datapump.dp DIRECTORY=d_test FULL=y LOGFILE=zj_datapump.log parallel=2

采用并行度為2的導(dǎo)入方式,發(fā)現(xiàn)速度果然提高了很多。并行度為1的導(dǎo)入速度是3小時8分鐘,而現(xiàn)在用了不到2個半小時。

由于并行度設(shè)置不應(yīng)該超過CPU數(shù)的2倍,因此嘗試平行度3和4的導(dǎo)入,導(dǎo)入時間和并行度2十分接近??磥硪呀?jīng)無法再使用通過提高并行度的方法來提高性能了。

1) 先看直接導(dǎo)出的性能:

$ expdp zhejiang/zhejiang directory=d_test dumpfile=zhejiang.dp

整個導(dǎo)出操作大概用了14分半,

 

2) 嘗試使用并行度2進行導(dǎo)出,這時仍然設(shè)置一個導(dǎo)出的數(shù)據(jù)文件:

$ expdp zhejiang/zhejiang directory=d_test dumpfile=zhejiang_p2_1file.dp parallel=2

整個導(dǎo)入過程不到14分鐘,不過這個性能的提升實在不是很明顯。不過這是有原因的,由于設(shè)置了并行度,兩個進程在同時執(zhí)行導(dǎo)出操作,但是二者要將導(dǎo)出的數(shù)據(jù)寫入同一個數(shù)據(jù)文件中,因此必然會導(dǎo)致資源的爭用

 

3) 仍然使用并行度2,但是同時設(shè)置兩個數(shù)據(jù)文件再次檢查導(dǎo)出性能:

$ expdp zhejiang/zhejiang directory=d_test dumpfile=zhejiang_p2_2file1.dp,zhejiang_p2_2file2.dp parallel=2

這次導(dǎo)出僅僅用了10分半,導(dǎo)出的效率大大的提高。

 

4) 測試一下并行度4,分別導(dǎo)出到4個數(shù)據(jù)文件中:

用了9分鐘整導(dǎo)出完成,設(shè)置成并行度4仍然可以獲得一定的性能提升,但是并不明顯了,這主要是由于整個性能的瓶頸已經(jīng)不是單個進程的處理能力,多半性能的瓶頸已經(jīng)變成了磁盤IO瓶頸,此時單單靠增加并行度已經(jīng)無法明顯提升性能了。

向AI問一下細節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI