如何在oracle中導入dmp數據庫文件?
oracle數據導入導出imp/exp就相當於oracle數據還原與備份。exp命令可以把數據從遠程數據庫服務器導出到本地的dmp文件,imp命令可以把dmp文件從本地導入到遠處的數據庫服務器中。 利用這個功能可以構建兩個相同的數據庫,一個用來測試,一個用來正式使用。 執行環境:可以在sqlplus.exe或者dos(命令行)中執行, dos中可以執行時由於在oracle 8i 中 安裝目錄\ora81\bin被設置為全局路徑, 該目錄下有exp.exe與imp.exe文件被用來執行導入導出。 oracle用java編寫,sqlplus.exe、exp.exe、imp.exe這兩個文件有可能是被包裝後的類文件。 sqlplus.exe調用exp.exe、imp.exe所包裹的類,完成導入導出功能。 下面介紹的是導入導出的實例。
數據導出:
1 將數據庫orcl(實例)完全導出(只有DBA才可以,普通用戶不可以),用戶名system 密碼manager 導出到d:\daochu.dmp中
exp system/manager@orcl file=d:\daochu.dmp full=y
2 將數據庫中system用戶與sys用戶的表導出
exp system/manager@orcl file=d:\daochu.dmp owner=(system,sys)
3 將數據庫中的表inner_notify、notify_staff_relat導出
exp scott/tiger@orcl file= d:\test.dmp tables=(inner_notify,notify_staff_relat)
4 將數據庫中的表table1中的字段filed1以"00"打頭的數據導出
exp system/manager@orcl file=d:\daochu.dmp tables=(table1) query=\" where filed1 like 00%\"
上面是常用的導出,對於壓縮,既用winzip把dmp文件可以很好的壓縮。也可以在上面命令後面加上 compress=y 來實現。
數據的導入
1 將d:\daochu.dmp 中的數據導入 test數據庫中。
imp system/manager@test file=d:\daochu.dmp
imp system/manager@test full=y file= d:\data\newsmgnt.dmp ignore=y
上面可能有點問題,因為有的表已經存在,然後它就報錯,對該表就不進行導入。
在後面加上 ignore=y 就可以了。
2 將d:\daochu.dmp中的表table1 導入
imp system/manager@test file=d:\daochu.dmp tables=(table1)
基本上上面的導入導出夠用了。不少情況要先是將表徹底刪除,然後導入。
注意: 操作者要有足夠的權限,權限不夠它會提示。 數據庫時可以連上的。可以用tnsping test 來獲得數據庫test能否連上。
附錄一:
給用戶增加導入數據權限的操作
第一,啟動sql*plus
第二,以system/manager登陸
第三,create user “用戶名” identified by “密碼”
(如果已經創建過用戶,這步可以省略)
第四,grant create user,drop user,alter user ,create any view ,drop any view,exp_full_database,imp_full_database,dba,connect,resource,create session to “用戶名字 ”
第五, 運行-cmd-進入dmp文件所在的目錄,
imp userid=system/manager full=y file=*.dmp
或者 imp userid=system/manager full=y file=filename.dmp
執行示例: f:\work\oracle_data\backup>imp userid=test/test full=y file=inner_notify.dmp
附錄二:
oracle 不允許直接改變表的擁有者, 利用export/import可以達到這一目的.
先建立import9.par, 然後,使用時命令如下:imp parfile=/filepath/import9.par
例 import9.par 內容如下:
fromuser=tgpms
touser=tgpms2
(注:把表的擁有者由fromuser改為touser,fromuser和touser的用戶可以不同)
rows=y
indexes=y
grants=y
constraints=y
buffer=409600
file==/backup/ctgpc_20030623.dmp
log==/backup/import_20030623.log
附錄三
EXP、IMP 命令詳解
命令詳解:
E:\>exp help=y
通過輸入 EXP 命令和用戶名/口令,您可以
在用戶 / 口令之後的命令:
實例: EXP SCOTT/TIGER
或者,您也可以通過輸入跟有各種參數的 EXP 命令來控制“導出”的運行方式。
要指定參數,您可以使用關鍵字:
格式: EXP KEYWORD=value 或KEYWORD=(value1,value2,...,valueN)
實例: EXP SCOTT/TIGER GRANTS=Y TABLES=(EMP,DEPT,MGR)
或 TABLES=(T1: P1,T1: P2),如果 T1 是分區表
USERID 必須是命令行中的第一個參數。
關鍵字 說明(默認)
---------------------------------------------------
USERID 用戶名/口令
FULL 導出整個文件 (N)
BUFFER 數據緩沖區的大小
OWNER 所有者用戶名列表
FILE 輸出文件 (EXPDAT.DMP)
TABLES 表名列表
COMPRESS 導入一個范圍 (Y)
RECORDLENGTH IO 記錄的長度
GRANTS 導出權限 (Y)
INCTYPE 增量導出類型
INDEXES 導出索引 (Y)
RECORD 跟蹤增量導出 (Y)
ROWS 導出數據行 (Y)
PARFILE 參數文件名
CONSTRAINTS 導出限制 (Y)
CONSISTENT 交叉表一致性
LOG 屏幕輸出的日志文件
STATISTICS 分析對象 (ESTIMATE)
DIRECT 直接路徑 (N)
TRIGGERS 導出觸發器 (Y)
FEEDBACK 顯示每 x 行 (0) 的進度
FILESIZE 各轉儲文件的最大尺寸
QUERY 選定導出表子集的子句
下列關鍵字僅用於可傳輸的表空間
TRANSPORT_TABLESPACE 導出可傳輸的表空間元數據 (N)
TABLESPACES 將傳輸的表空間列表
E:\>imp help=y
可以通過輸入 IMP 命令和您的用戶名/口令
跟有您的用戶名 / 口令的命令:
實例: IMP SCOTT/TIGER
或者, 可以通過輸入 IMP 命令和各種自變量來控制“導入”按照不同參數。
要指定參數,您可以使用關鍵字:
格式: IMP KEYWORD=value 或KEYWORD=(value1,value2,...,vlaueN)
實例: IMP SCOTT/TIGER IGNORE=Y TABLES=(EMP,DEPT) FULL=N
或 TABLES=(T1: P1,T1: P2),如果 T1 是分區表
USERID 必須是命令行中的第一個參數。
關鍵字 說明(默認)
----------------------------------------------
USERID 用戶名/口令
FULL 導入整個文件 (N)
BUFFER 數據緩沖區大小
FROMUSER 所有人用戶名列表
FILE 輸入文件 (EXPDAT.DMP)
TOUSER 用戶名列表
SHOW 只列出文件內容 (N)
TABLES 表名列表
IGNORE 忽略創建錯誤 (N)
RECORDLENGTH IO 記錄的長度
GRANTS 導入權限 (Y)
INCTYPE 增量導入類型
INDEXES 導入索引 (Y)
COMMIT 提交數組插入 (N)
ROWS 導入數據行 (Y)
PARFILE 參數文件名
LOG 屏幕輸出的日志文件
CONSTRAINTS 導入限制 (Y)
DESTROY 覆蓋表空間數據文件 (N)
INDEXFILE 將表/索引信息寫入指定的文件
SKIP_UNUSABLE_INDEXES 跳過不可用索引的維護 (N)
ANALYZE 執行轉儲文件中的 ANALYZE 語句 (Y)
FEEDBACK 顯示每 x 行 (0) 的進度
TOID_NOVALIDATE 跳過指定類型 id 的校驗
FILESIZE 各轉儲文件的最大尺寸
RECALCULATE_STATISTICS 重新計算統計值 (N)
下列關鍵字僅用於可傳輸的表空間
TRANSPORT_TABLESPACE 導入可傳輸的表空間元數據 (N)
TABLESPACES 將要傳輸到數據庫的表空間
DATAFILES 將要傳輸到數據庫的數據文件
TTS_OWNERS 擁有可傳輸表空間集中數據的用戶
---------------------------------------------------------------------------------------
如果只導出表的結構(建表語句),不導出表的數據,可用Tools--Export User Objects
選中要導出的表,設置好導出的路徑和各個參數後,點擊Export就OK
PS:這種方式只能導出屬於這個用戶的表,其他用戶的表不能導出,建議用命令行導出(exp, imp)
如果想將表結構,表的數據,觸發器,函數之類的全部導出,可用Tools--Export Tables
選中要導出的表(可選多個),導出方式有三種:
Oracle Export,Sql Insert,pl/sql developer
第一種是導出為.dmp的文件格式,.dmp文件是二進制的,可以跨平台,還能包含權限,效率也很不錯,用的最廣。
第二種是導出為.sql文件的,選中create tables選項,where clause 裡寫入 where rownum<1可用文本編輯器查看,通用性比較好,但效率不如第一種,適合小數據量導入導出。尤其注意的是表中不能有大字段(blob,clob),如果有,會提示不能導出,可以用第一種和第三種方式導出。
第三種是導出為.pde格式的,.pde為Pl/sql developer自有的文件格式,只能用Pl/sql developer自己導入導出;不能用編輯器查看,效率不知道怎麼樣
PS:只有“Oracle Export”方式導出再導入後,表結構和索引結構沒有發生變化,另兩種方式都改變了索引類型。
導入的情況和導出一樣
在表的所有者不能改變的情況下,可以使用導入導出表結構和表數據的方法,將表移動到你想要的所有者下(注:特別是建立表的時候如果以sysdba的身份登錄的話,所有表的所有者都為sys,此時會對你用c#訪問數據庫產生麻煩,我在我的另一篇文章中也提到《.NET連接Oracle數據庫的錯誤,pl/sql中的myobjects過濾器 》),此時你只能用這種方法改變所有者。
導入表結構:
執行剛剛導出的sql文件,記住要刪掉table前的用戶名,比如以前這表名為sys.tablename,必須刪除sys
導入表數據:
執行剛剛導出的sql文件