溫馨提示×

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

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

exp和expdp導(dǎo)入導(dǎo)出 Oracle10g學(xué)習(xí)系列(8)

發(fā)布時(shí)間:2020-08-05 14:32:27 來(lái)源:網(wǎng)絡(luò) 閱讀:1002 作者:zddnyl 欄目:關(guān)系型數(shù)據(jù)庫(kù)

一、使用二者時(shí)應(yīng)該注意的事項(xiàng):


1、exp和imp是客戶端工具程序,它們既可以在客戶端使用,也可以在服務(wù)端使用。expdpimpdp是服務(wù)端的工具程序,他們只能在oracle服務(wù)端使用,不能在客戶端使用。


expdp impdp導(dǎo)大文件比exp和imp快,可以并行導(dǎo),但導(dǎo)小文件很慢。網(wǎng)上有人說(shuō)一個(gè)600G的庫(kù),expdp只需要40分鐘左右,exp的話要50個(gè)小時(shí)吧


imp只適用于exp導(dǎo)出的文件,不適用于expdp導(dǎo)出文件;impdp只適用于expdp導(dǎo)出的文件,而不適用于exp導(dǎo)出文件。


二、exp和expdp的簡(jiǎn)單用法:


1、exp備份

(1)按表名導(dǎo),tables=tb2,tb3,導(dǎo)多張表的時(shí)候,可以用逗號(hào)或空格分隔

exp bob/qazwsx@orcl tables=tb2,tb3 file=/tmp/baktb01.dmp  log=/tmp/baktb01.log


(2)按用戶導(dǎo),owner=bob,會(huì)把該用戶下的所有表導(dǎo)出

exp bob/qazwsx@orcl owner=bob file=/tmp/baktb02.dmp log=/tmp/baktb02.log


(3)導(dǎo)出全庫(kù),full=y,用system或者有sysdba權(quán)限用戶導(dǎo)

exp bob/qazwsx@orcl full=y file=/tmp/baktb03.dmp  log=/tmp/baktb03.log


(4)如果導(dǎo)出表文件超過(guò)2G報(bào)錯(cuò),可以分多個(gè)文件導(dǎo)出

exp bob/qazwsx@orcl filesize=1g tables=tb2,tb3 file=/tmp/tb01.dmp,/tmp/tb02.dmp   log=/tmp/baktb04.log


(5)導(dǎo)出表結(jié)構(gòu)

  exp bob/qazwsx@orcl rows=n tables=tb2  file=/tmp/baktb04.dmp


(6)導(dǎo)出表數(shù)據(jù) 

 exp bob/qazwsx@orcl rows=y tables=tb2  file=/tmp/baktb05.dmp


2、imp還原

(1)還原表

imp bob/qazwsx@orcl tables=tb2,tb3 file=/tmp/baktb01.dmp log=/tmp/baktb01.log


如果表已經(jīng)存在或者需要忽略表結(jié)構(gòu),ignore=y,需要用忽略參數(shù)

imp bob/qazwsx@orcl tables=tb2,tb3 file=/tmp/baktb01.dmp ignore=y log=/tmp/baktb01.log


(2)還原該用戶下的所有表

imp bob/qazwsx@orcl owner=bob file=/tmp/baktb02.dmp log=/tmp/baktb02.log


(3)庫(kù)還原

imp bob/qazwsx@orcl full=y file=/tmp/baktb03.dmp log=/tmp/baktb03.log


3、expdp備份

有sysdba權(quán)限的用戶,在/tmp/下創(chuàng)建expdp目錄,并且給導(dǎo)入導(dǎo)出權(quán)限

SQL>create directory expdp as ‘/tmp/’;

SQL>grant read,write on directory expdp to bob; 


(1)按表名導(dǎo),tables=tb2,tb3,導(dǎo)多張表的時(shí)候,可以用逗號(hào)或空格分隔

expdp bob/qazwsx@orcl tables=tb2,tb3 directory=expdp dumpfile=bak01.dmp logfile=expdp01.log


(2)按用戶導(dǎo),schemas=bob,會(huì)把該用戶下的所有表導(dǎo)出

expdp bob/qazwsx@orcl schemas=bob directory=expdp dumpfile=bak02.dmp logfile=expdp02.log


(3)導(dǎo)出全庫(kù),full=y,用system或者有sysdba權(quán)限用戶導(dǎo)

expdp bob/qazwsx@orcl full=y directory=expdp dumpfile=bak03.dmp logfile=expdp03.log

或者expdp \'sys/oracle as sysdba\' full=y directory=expdp dumpfile=full.dmp


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

expdp bob/qazwsx@orcl directory=expdp dumpfile=bak04.dmp tables=emp query='WHERE deptno=20'


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

expdp bob/qazwsx@orcl directory=expdp dumpfile=tablespace.dmp tablespaces=temp,example


4、impdp還原

(1)還原表

impdp bob/qazwsx@orcl tables=tb2,tb3 directory=expdp dumpfile=bak01.dmp 


(2)還原該用戶下的所有表

impdp bob/qazwsx@orcl schemas=bob directory=expdp dumpfile=bak02.dmp


(3)庫(kù)還原

impdp bob/qazwsx@orcl full=y directory=expdp dumpfile=bak03.dmp


(4)追加,如果表結(jié)構(gòu)存在用append

impdp scott/tiger dumpfile=expdp:scott.bak tables=emp tables_exists_action=append


(5)替換,不會(huì)釋放表空間

impdp scott/tiger dumpfile=expdp:scott.bak tables=emp tables_exists_action=replace



(6)截?cái)?,?huì)釋放空間,重新插入新的數(shù)據(jù)

impdp scott/tiger dumpfile=expdp:scott.bak tables=emp tables_exists_action=truncate


(7)只恢復(fù)emp表的時(shí)候,另外兩個(gè)表會(huì)跳過(guò)恢復(fù)

impdp scott/tiger dumpfile=expdp:scott.bak tables=emp,dept,salgrade tables_exists_action=skip


(8)改變表的owner:

例子:impdp user/passwd direcotry=xxx dumpfile=xxx.dmp remap_schema=原schema:新schema名字 logfile=xxx.log

impdp system/manager DIRECTORY=dpdata1 DUMPFILE=expdp.dmp TABLES=scott.dept REMAP_SCHEMA=scott:system;


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

impdp system/manager DIRECTORY=dpdata1 DUMPFILE=tablespace.dmp TABLESPACES=example;




向AI問(wèn)一下細(xì)節(jié)

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

AI