欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Oracle數(shù)據(jù)IMP和EXP命令用法詳解

 更新時間:2023年11月25日 11:03:51   作者:沒有實現(xiàn)不了的夢  
這篇文章主要給大家介紹了關(guān)于Oracle數(shù)據(jù)IMP和EXP命令用法詳解的相關(guān)資料,我們可以使用Oracle自帶的exp、imp命令來進(jìn)行數(shù)據(jù)庫備份,imp和exp稱之為導(dǎo)入導(dǎo)出,這種方式也能快速的導(dǎo)入導(dǎo)出table或數(shù)據(jù)庫,需要的朋友可以參考下

前言

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)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 基于ora2pg遷移Oracle19C到postgreSQL14的全過程

    基于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 客戶端安裝步驟(圖文詳解)

    這篇文章主要介紹了分享Oracle 11G Client 客戶端安裝步驟(圖文詳解),非常具有實用價值,需要的朋友可以參考下。
    2016-12-12
  • oracle 數(shù)據(jù)庫隔離級別學(xué)習(xí)

    oracle 數(shù)據(jù)庫隔離級別學(xué)習(xí)

    這篇文章主要介紹了oracle數(shù)據(jù)庫的隔離級別相關(guān)的知識,數(shù)據(jù)庫操作的隔離級別,有需要的朋友可以參考下
    2014-05-05
  • Oracle實現(xiàn)主鍵字段自增的四種方式

    Oracle實現(xiàn)主鍵字段自增的四種方式

    眾所周知MySQL數(shù)據(jù)庫的主鍵自增設(shè)置非常簡單,任何一個常用的可視化工具都支持,只要打一下勾就可以開啟主鍵自增了,然而Oracle并沒有那么簡單,這篇文章主要給大家介紹了關(guān)于Oracle實現(xiàn)主鍵字段自增的四種方式,需要的朋友可以參考下
    2023-03-03
  • Oracle數(shù)據(jù)庫的系統(tǒng)結(jié)構(gòu)

    Oracle數(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-07
  • Oracle創(chuàng)建和管理分區(qū)索引的操作方法

    Oracle創(chuàng)建和管理分區(qū)索引的操作方法

    創(chuàng)建和管理分區(qū)索引(Partitioned Index)是數(shù)據(jù)庫管理中的重要任務(wù),特別是在處理大規(guī)模數(shù)據(jù)集時,以下是如何在Oracle數(shù)據(jù)庫中創(chuàng)建和管理分區(qū)索引的詳細(xì)步驟和示例代碼,感興趣的朋友一起看看吧
    2024-08-08
  • oracle?指定類型和指定位數(shù)創(chuàng)建序列號的代碼詳解

    oracle?指定類型和指定位數(shù)創(chuàng)建序列號的代碼詳解

    這篇文章主要介紹了oracle?指定類型和指定位數(shù)創(chuàng)建序列號,本文通過實例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-05-05
  • Oracle 12CR2查詢轉(zhuǎn)換教程之表擴展詳解

    Oracle 12CR2查詢轉(zhuǎn)換教程之表擴展詳解

    Oracle 12cR2版本已經(jīng)發(fā)布有一段時間,下面這篇文章主要給大家介紹了關(guān)于Oracle 12CR2查詢轉(zhuǎn)換教程之表擴展的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考借鑒,下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2018-11-11
  • oracle數(shù)據(jù)庫id自增及生成uuid問題

    oracle數(shù)據(jù)庫id自增及生成uuid問題

    這篇文章主要介紹了oracle數(shù)據(jù)庫id自增及生成uuid問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-05-05
  • Oracle 數(shù)據(jù)庫優(yōu)化實戰(zhàn)心得總結(jié)

    Oracle 數(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

最新評論