oracle中exp/imp讲解

前端之家收集整理的这篇文章主要介绍了oracle中exp/imp讲解前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

Exp/Imporacle备份数据的两个命令行工具

1.本地数据库导入导出

1.导出

(运行---cmd中操作)

exp@R_301_473@/密码@数据库实例名file=本地存放路径

eg: exp jnjp/jnjp@ORCL file=C:/jnjp.dmp

2.导入

imp@R_301_473@/密码@数据库实例名file=本地数据库文件存放路径full=y ignore=y

eg: imp jnjp/jnjp@orcl file=E:\jnjp.dmp full=yignore=y

2.远程数据库导入导出

1.导出

exp@R_301_473@/密码@ip地址/数据库实例名file=本地存放路径

eg: exp jnjp/jnjp@10.15.135.18/orcl file=C:/jnjp.dmp

imp@R_301_473@/密码@ip地址/数据库实例名file=本地数据库文件存放路径full=y

3.EXP的所有参数(括号中为参数的默认值)

USERID @R_301_473@/口令 如:USERID=duanl/duanl

FULL 导出整个数据库(N)

BUFFER 数据缓冲区的大小

OWNER 所有者@R_301_473@列表,你希望导出哪个用户的对象,就用owner=username

FILE 输出文件(EXPDAT.DMP)

TABLES 表名列表,指定导出的table名称,如:TABLES=table1,table2

COMPRESS 导入一个extent (Y)

RECORDLENGTH IO记录的长度

GRANTS 导出权限(Y)

INCTYPE 增量导出类型

INDEXES 导出索引(Y)

RECORD 跟踪增量导出(Y)

ROWS 导出数据行(Y)

PARFILE 参数文件,如果你exp的参数很多,可以存成参数文件.

CONSTRAINTS 导出约束(Y)

CONSISTENT 交叉表一致性

LOG 屏幕输出的日志文件

STATISTICS 分析对象(ESTIMATE)

DIRECT 直接路径(N)

TRIGGERS 导出触发器(Y)

FeedBACK 显示x(0)的进度

FILESIZE 各转储文件的最大尺寸

QUERY 选定导出表子集的子句

下列关键字仅用于可传输的表空间

TRANSPORT_TABLESPACE导出可传输的表空间元数据(N)

TABLESPACES将传输的表空间列表

4.IMP的所有参数(括号中为参数的默认值)

USERID @R_301_473@/口令

FULL 导入整个文件(N)

BUFFER 数据缓冲区大小

FROMUSER 所有人@R_301_473@列表

FILE 输入文件(EXPDAT.DMP)

TOUSER @R_301_473@列表

SHOW 只列出文件内容(N)

TABLES 表名列表

IGNORE 忽略创建错误(N)

GRANTS 导入权限(Y)

INCTYPE 增量导入类型

INDEXES导入索引(Y)

COMMIT 提交数组插入(N)

ROWS 导入数据行(Y)

PARFILE 参数文件

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拥有可传输表空间集中数据的用户

5.EXP常用选项

1.FULL

这个用于导出整个数据库,在ROWS=N一起使用时,可以导出整个数据库的结构。例如:

exp userid=test/test file=./db_str.dmp log=./db_str.log full=y rows=n compress=y direct=y

注:在oracle10g中,userid这个是可以不用写的直接写 @R_301_473@/密码 就可以了像这样:

exp test/test file=./db_str.dmp log=./db_str.log full=y rows=n compress=y direct=y

2.OWNERTABLE

这两个选项用于定义EXP的对象。OWNER定义导出指定用户的对象;TABLE指定EXPtable名称,例如:

exp userid=test/test file=./db_str.dmp log=./db_str.log owner=duanl

:有的时候我们可能会遇到只导出单表的情况,下面这种方法可以帮你解决问题

exp userid=test/test file=./db_str.dmp log=./db_str.log table=nc_data,fi_arap

3.FILELOG

这两个参数分别指定备份的DMP名称LOG名称包括文件名和目录,例子见上面。

4.COMPRESS

COMPRESS参数不压缩导出数据的内容。用来控制导出对象的storage语句如何产生。默认值为Y,使用默认值,对象的存储语句的init extent等于当前导出对象的extent的总和。推荐使用COMPRESSN

6.IMP常用选项

1FROMUSERTOUSER

使用它们实现将数据从一个SCHEMA中导入到另外一个SCHEMA中。例如:假设我们做exp时导出的为test的对象,现在我们想把对象导入用户

imp userid=test1/test1 file=expdat.dmp fromuser=test1 touser=test1

2、IGNOREGRANTSINDEXES

其中IGNORE参数将忽略表的存在,继续导入,这个对于需要调整表的存储参数时很有用,我们可以先根据实际情况用合理的存储参数建好表,然后直接导入数据。而GRANTSINDEXES则表示是否导入授权和索引,如果想使用新的存储参数重建索引,或者为了加快到入速度,我们可以考虑将INDEXES设为N,而GRANTS一般都是Y。例如:imp userid=test1/test1 file=expdat.dmp fromuser=test1 touser=test1 indexes=N

7.导入导出实例

下面介绍的是导入导出的实例,向导入导出看实例基本上就可以完成,因为导入导出很简单。

1.数据导出:

1.1将数据库TEST完全导出,@R_301_473@system密码manager导出到D:\daochu.dmp

exp system/manager@TEST file=d:\daochu.dmp full=y

1.2数据库system用户sys用户的表导出

exp system/manager@TEST file=d:\daochu.dmp owner=(system,sys)

1.3数据库中的表table1table2导出

exp system/manager@TEST file=d:\daochu.dmp tables=(table1,table2)

1.4数据库中的表table1中的字段filed1"00"打头的数据导出

exp system/manager@TEST file=d:\daochu.dmp tables=(table1) query=\" where filed1 like '00%'\"

2.数据的导入:

2.1D:\daochu.dmp中的数据导入TEST数据库中。

imp system/manager@TEST file=d:\daochu.dmp

上面可能有点问题,因为有的表已经存在,然后它就报错,对该表就不进行导入。

在后面加上ignore=y就可以了。

2.2d:\daochu.dmp中的表table1导入

imp system/manager@TEST file=d:\daochu.dmp tables=(table1)

基本上上面的导入导出够用了。不少情况我是将表彻底删除,然后导入。

3.导出、导入通配符的使用:

想导出格式为TABLE_1,TABLE_2,TABLE_3这样的表,这样的表在库中共有300张,难道要一张张的写语句?太费神了吧,不用担心,oracle提供通配符可以使用来满足这样的需求:

exp system/test@192.168.1.198/orcl file=d:\exp_test.dmptables=TABLE_% log=exp_test.log

参考资料:http://sucre.iteye.com/blog/424760

猜你在找的Oracle相关文章