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

