Oracle數(shù)據(jù)IMP和EXP命令用法詳解
前言
Oracle 的 EXP(Export)和 IMP(Import)是兩個非常重要的命令,它們用于數(shù)據(jù)庫的備份和恢復(fù)。下面我們將詳細(xì)介紹這兩個命令及其參數(shù)的用法。
1. EXP(Export)
EXP命令可以看作是一個搬運工人,他的工作就是將你指定的物品(數(shù)據(jù))從Oracle數(shù)據(jù)庫搬出,并打包成一個 .dmp
文件。這個過程就像是你要搬家,需要將你的所有物品打包好,準(zhǔn)備搬到新家。
以下是EXP命令的一般格式和常用參數(shù):
exp userid=<用戶名>/<密碼>@<數(shù)據(jù)庫連接> file=<導(dǎo)出文件的路徑和名稱> owner=<要導(dǎo)出的用戶名稱> tables=<要導(dǎo)出的表名稱> full=<是否全庫導(dǎo)出>
userid
:這是告訴搬運工人鑰匙在哪(數(shù)據(jù)庫連接信息),以及如何開門(用戶名和密碼)。file
:這是告訴搬運工人將物品搬到哪個箱子里(即導(dǎo)出文件的路徑和名稱)。owner
:這是指定要導(dǎo)出哪個公司的物品(即用戶名稱)。如果沒有指定,那么搬運工人將打包你擁有權(quán)限的所有物品。tables
:這是指定要搬運哪些特定的物品(即表名稱)。如果沒有指定,那么就搬運全部的物品。full
:這是告訴搬運工人是否要打包整棟樓的物品(即是否全庫導(dǎo)出)。如果設(shè)置為y
,則不論你是否擁有權(quán)限,只要能搬走的,他都會搬。
舉例
假設(shè)我們有一個用戶名為scott
,密碼為tiger
,在數(shù)據(jù)庫orcl
中,我們想導(dǎo)出該用戶下的所有表,并保存到D:\backup\scott.dmp
。
exp scott/tiger@orcl file=D:\backup\scott.dmp owner=scott
在這個命令中:
- 必須的參數(shù):
userid
(在這里是scott/tiger@orcl
),file
(在這里是D:\backup\scott.dmp
) - 可選的參數(shù):
owner
,tables
,full
2. IMP(Import)
IMP命令就像是EXP的反向操作,是另一位搬運工人,他的工作是從 .dmp
文件中取出物品(數(shù)據(jù))并將它們放入Oracle數(shù)據(jù)庫。這個過程就像是你搬到新家后,需要將你的物品從箱子中取出并放置到合適的位置。
以下是IMP命令的一般格式和常用參數(shù):
imp userid=<用戶名>/<密碼>@<數(shù)據(jù)庫連接> file=<導(dǎo)入文件的路徑和名稱> fromuser=<原用戶> touser=<新用戶> tables=<要導(dǎo)入的表名稱> full=<是否全庫導(dǎo)入> ignore=<是否忽略錯誤>
userid
:這是告訴搬運工人鑰匙在哪(數(shù)據(jù)庫連接信息),以及如何開門(用戶名和密碼)。file
:這是告訴搬運工人在哪個箱子里取物品(即導(dǎo)入文件的路徑和名稱)。fromuser
:這是告訴搬運工人原來的物品是屬于哪個公司的(即原用戶)。touser
:這是告訴搬運工人將物品放到新公司的哪個地方(即新用戶)。tables
:這是指定搬運工人取出箱子中的哪些特定物品(即表名稱)。如果沒有指定,那么就取出全部的物品。full
:這是告訴搬運工人是否要把箱子里的所有物品都取出并放到新家(即是否全庫導(dǎo)入)。如果設(shè)置為y
,則不論是否需要,只要箱子里有,他都會取出來。ignore=y
:如果目標(biāo)表已存在,將忽略錯誤,繼續(xù)將數(shù)據(jù)導(dǎo)入到已存在的表中。
舉例
假設(shè)我們想將上面導(dǎo)出的文件D:\backup\scott.dmp
導(dǎo)入到用戶scott
,密碼為tiger
在數(shù)據(jù)庫orcl
中。
命令如下:
imp scott/tiger@orcl file=D:\backup\scott.dmp fromuser=scott touser=scott
在這個命令中:
- 必須的參數(shù):
userid
(在這里是scott/tiger@orcl
),file
(在這里是D:\backup\scott.dmp
) - 可選的參數(shù):
fromuser
,touser
,tables
,full
希望以上的解釋能幫助你理解EXP和IMP命令的工作方式。
使用導(dǎo)入工具imp時可能出現(xiàn)的問題 :
(1) 數(shù)據(jù)庫對象已經(jīng)存在
一般情況, 導(dǎo)入數(shù)據(jù)前應(yīng)該徹底刪除目標(biāo)數(shù)據(jù)下的表, 序列, 函數(shù)/過程,觸發(fā)器等;
數(shù)據(jù)庫對象已經(jīng)存在, 按缺省的imp參數(shù), 則會導(dǎo)入失敗
如果用了參數(shù)ignore=y, 會把exp文件內(nèi)的數(shù)據(jù)內(nèi)容導(dǎo)入
如果表有唯一關(guān)鍵字的約束條件, 不合條件將不被導(dǎo)入
如果表沒有唯一關(guān)鍵字的約束條件, 將引起記錄重復(fù)
(2) 數(shù)據(jù)庫對象有主外鍵約束
不符合主外鍵約束時, 數(shù)據(jù)會導(dǎo)入失敗
解決辦法: 先導(dǎo)入主表, 再導(dǎo)入依存表
disable目標(biāo)導(dǎo)入對象的主外鍵約束, 導(dǎo)入數(shù)據(jù)后, 再enable它們
(3) 權(quán)限不夠
如果要把A用戶的數(shù)據(jù)導(dǎo)入B用戶下, A用戶需要有imp_full_database權(quán)限
(4) 導(dǎo)入大表( 大于80M ) 時, 存儲分配失敗
默認(rèn)的EXP時, compress = Y, 也就是把所有的數(shù)據(jù)壓縮在一個數(shù)據(jù)塊上
導(dǎo)入時, 如果不存在連續(xù)一個大數(shù)據(jù)塊, 則會導(dǎo)入失敗
導(dǎo)出80M以上的大表時, 記得compress= N, 則不會引起這種錯誤
(5) imp和exp使用的字符集不同
如果字符集不同, 導(dǎo)入會失敗, 可以注冊表里NLS_LANG相關(guān)信息
導(dǎo)入完成后再改回來
--查詢當(dāng)前系統(tǒng)所使用的字符集 select * from v$nls_parameters where parameter='NLS_CHARACTERSET';
--查詢所有有關(guān)字符集的參數(shù) select * from v$nls_parameters;
修改系統(tǒng)的字符集:
在oracle8之前,可以用直接修改數(shù)據(jù)字典表props$ 來改變數(shù)據(jù)庫的字符集,但oracle8之后,至少有三張系統(tǒng)表記錄了數(shù)據(jù)庫字符集的信息,只改props$表并不完全,可能引起嚴(yán)重的后果。正確的修改方法如下
若此時數(shù)據(jù)庫服務(wù)器已啟動,則先執(zhí)行SHUTDOWN IMMEDIATE命令關(guān)閉數(shù)據(jù)庫服務(wù)器,然后執(zhí)行以下命令:
SQL>STARTUP MOUNT; SQL>ALTER SYSTEM ENABLE RESTRICTED SESSION; SQL>ALTER SYSTEM SET JOB_QUEUE_PROCESSES=0; SQL>ALTER SYSTEM SET AQ_TM_PROCESSES=0; SQL>ALTER DATABASE OPEN; SQL>ALTER DATABASE CHARACTER SET INTERNAL_USE ZHS16GBK; //跳過超子集檢測 AL32UTF8; SQL>ALTER DATABASE national CHARACTER SET INTERNAL ZHS16GBK;AL32UTF8;
流程為:關(guān)庫,啟動數(shù)據(jù)庫到mount狀態(tài),進(jìn)入數(shù)據(jù)庫維護(hù)模式,此時只有system和sys用戶可登錄數(shù)據(jù)庫。關(guān)閉DBMS調(diào)度程序和DBMS調(diào)度任務(wù),關(guān)閉自動任務(wù)啟動,跳過字符超子集檢查,設(shè)定系統(tǒng)字符集,關(guān)庫,重新啟動數(shù)據(jù)庫。
(6) imp和exp版本不能往上兼容
imp可以成功導(dǎo)入低版本exp生成的文件, 不能導(dǎo)入高版本exp生成的文件
根據(jù)情況我們可以用
exp和imp與數(shù)據(jù)泵expdp和impdp的區(qū)別:
1、exp和imp是客戶端工具程序,它們既可以在客戶端使用,也可以在服務(wù)端使用。exp在客戶端使用,要受到網(wǎng)速的影響,因此會比較慢。
2、expdp和impdp是服務(wù)端的工具程序,他們只能在Oracle服務(wù)端使用,不能在客戶端使用。
3、imp只適用于exp導(dǎo)出的文件,不適用于expdp導(dǎo)出文件;impdp只適用于expdp導(dǎo)出的文件,而不適用于exp導(dǎo)出文件。
4、對于10g以上的服務(wù)器,使用exp通常不能導(dǎo)出0行數(shù)據(jù)的空表,而此時必須使用expdp導(dǎo)出。
5、數(shù)據(jù)泵expdp和impdp導(dǎo)出可以使用parallel屬性指定并行任務(wù)導(dǎo)出,parallel=2就是并行2個任務(wù)導(dǎo)出。當(dāng)然,這個并不是越多越好,需要考慮服務(wù)器的性能和cpu的個數(shù)等等因素。還可以通過導(dǎo)出多個文件的方式提高性能,即使用dumpfile=expdp.dp1,expdp.dp2這種方式提高性能。需要用戶根據(jù)實際情況設(shè)置
6、exp導(dǎo)出時讀取的是sql,通過加載sql查詢結(jié)果到緩存,然后在寫進(jìn)目標(biāo)文件,而expdp是直接讀取的數(shù)據(jù)塊,直接從數(shù)據(jù)塊寫進(jìn)目標(biāo)文件。
總結(jié)
到此這篇關(guān)于Oracle數(shù)據(jù)IMP和EXP命令用法詳解的文章就介紹到這了,更多相關(guān)Oracle IMP和EXP命令內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- Oracle數(shù)據(jù)泵EXPDP/IMPDP導(dǎo)出導(dǎo)入功能詳細(xì)深入解析
- Oracle 11g數(shù)據(jù)庫使用expdp每周進(jìn)行數(shù)據(jù)備份并上傳到備份服務(wù)器
- 基于oracle expdp命令的使用詳解
- 使用imp和exp命令對Oracle數(shù)據(jù)庫進(jìn)行導(dǎo)入導(dǎo)出操作詳解
- oracle中exp,imp的使用詳解
- Oracle 管道 解決Exp/Imp大量數(shù)據(jù)處理問題
- Oracle 數(shù)據(jù)庫導(dǎo)出(exp)導(dǎo)入(imp)說明
- Oracle expdp/impdp 及 exp/imp 命令詳解
相關(guān)文章
基于ora2pg遷移Oracle19C到postgreSQL14的全過程
ora2pg是一個開源工具,可將Oracle數(shù)據(jù)庫模式轉(zhuǎn)換為PostgreSQL格式,支持導(dǎo)出數(shù)據(jù)庫絕大多數(shù)對象類型,本文就給大家介紹了基于ora2pg遷移Oracle19C到postgreSQL14的全過程,文中有詳細(xì)的代碼示例,需要的朋友可以參考下2023-11-11分享Oracle 11G Client 客戶端安裝步驟(圖文詳解)
這篇文章主要介紹了分享Oracle 11G Client 客戶端安裝步驟(圖文詳解),非常具有實用價值,需要的朋友可以參考下。2016-12-12oracle 數(shù)據(jù)庫隔離級別學(xué)習(xí)
這篇文章主要介紹了oracle數(shù)據(jù)庫的隔離級別相關(guān)的知識,數(shù)據(jù)庫操作的隔離級別,有需要的朋友可以參考下2014-05-05Oracle數(shù)據(jù)庫的系統(tǒng)結(jié)構(gòu)
這篇文章主要介紹了Oracle數(shù)據(jù)庫的系統(tǒng)結(jié)構(gòu),Oracle數(shù)據(jù)庫的存儲結(jié)構(gòu)(Storage Structure)分為物理存儲結(jié)構(gòu)和邏輯存儲結(jié)構(gòu)兩種,分別描述了在操作系統(tǒng)中和數(shù)據(jù)庫系統(tǒng)內(nèi)部數(shù)據(jù)的組織管理方式,需要的朋友可以參考下2023-07-07Oracle創(chuàng)建和管理分區(qū)索引的操作方法
創(chuàng)建和管理分區(qū)索引(Partitioned Index)是數(shù)據(jù)庫管理中的重要任務(wù),特別是在處理大規(guī)模數(shù)據(jù)集時,以下是如何在Oracle數(shù)據(jù)庫中創(chuàng)建和管理分區(qū)索引的詳細(xì)步驟和示例代碼,感興趣的朋友一起看看吧2024-08-08oracle?指定類型和指定位數(shù)創(chuàng)建序列號的代碼詳解
這篇文章主要介紹了oracle?指定類型和指定位數(shù)創(chuàng)建序列號,本文通過實例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-05-05Oracle 12CR2查詢轉(zhuǎn)換教程之表擴展詳解
Oracle 12cR2版本已經(jīng)發(fā)布有一段時間,下面這篇文章主要給大家介紹了關(guān)于Oracle 12CR2查詢轉(zhuǎn)換教程之表擴展的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考借鑒,下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2018-11-11oracle數(shù)據(jù)庫id自增及生成uuid問題
這篇文章主要介紹了oracle數(shù)據(jù)庫id自增及生成uuid問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-05-05Oracle 數(shù)據(jù)庫優(yōu)化實戰(zhàn)心得總結(jié)
優(yōu)化sql語句、優(yōu)化io、表設(shè)計優(yōu)化、充分利用系統(tǒng)cpu資源、優(yōu)化數(shù)據(jù)庫連接、充分利用數(shù)據(jù)的后臺處理方案減少網(wǎng)絡(luò)流量,實施系統(tǒng)資源管理分配計劃等等,感興趣的朋友可以參考下哈2013-06-06