Exp/Imp是oracle备份数据的两个命令行工具

1.本地数据库导入导出

1.导出

(运行---cmd中操作)

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

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

2.导入

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

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

2.远程数据库导入导出

1.导出

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

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

2.导入

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

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

USERID        用户名/口令      如:USERID=duanl/duanl

FULL          导出整个数据库 (N)

BUFFER        数据缓冲区的大小

OWNER        所有者用户名列表,你希望导出哪个用户的对象,就用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    用户名/口令

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

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这个是可以不用写的直接写 用户名/密码 就可以了像这样:

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

2.OWNER和TABLE

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

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.FILE和LOG

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

4.COMPRESS

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

6.IMP常用选项

1、FROMUSER和TOUSER

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

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

2、IGNORE、GRANTS和INDEXES

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

7.导入导出实例

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

1.数据导出:

1.1将数据库TEST完全导出,用户名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 将数据库中的表table1、table2导出

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.1 将D:\daochu.dmp中的数据导入TEST数据库中。

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

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

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

2. 2 将d:\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

oracle 导入导出表,库的更多相关文章

  1. Oracle导入导出表

    使用PL SQL Developer进行操作 一.导出 工具<<导出表<<sql插入<<选择用户和要导出的表,勾选创建表,选择输出文件(格式最好为.sql),点击导 ...

  2. PLSQL Developer oracle导入导出表及数据

    1.进入PLSQL Developer 2.创建新用户(如需要新表空间则需先创建新表空间再创建用户) 3.打开菜单Tools->Export User Objects 导出表及视图等创建SQL ...

  3. oracle 导入导出表

    imp username/pwd@orcl file=c:\temp\exp.dmp tables=(table1, table2)#imp username/pwd@ip:1521/orcl ful ...

  4. oracle 导入导出功能

    关于expdp和impdp 使用EXPDP和IMPDP时应该注意的事项: EXP和IMP是客户端工具程序,它们既可以在客户端使用,也可以在服务端使用. - EXPDP和IMPDP是服务端的工具程序,他 ...

  5. Oracle导入导出之dmp

    Oracle导入导出有两种方式,分别是imp/exp与impdp/expdp. 1.imp/exp exp scott/tiger file=d:\test.dmp log=d:\test.log o ...

  6. Oracle 导入、导出DMP(备份)文件

    首先说明dmp文件: Oracle备份文件是以dmp结尾,这种文件是oracle的逻辑备份文件,常用于数据库逻辑备份,数据库迁移等操作. 一.Oracle导入备份文件步骤:我用的是Oracle 11g ...

  7. mysql导入导出表结构

    mysql导入导出表结构 导出整个库的表结构如下:mysqldump -uroot -p -d databasename > createtab.sql 如果只想导出表: test1,test2 ...

  8. Oracle 导入导出 创建用户等

    localhost:1158/emD:\app\Administrator\product\11.2.0\dbhome_1\bin\imp.exe log  path  E:\app\Administ ...

  9. CDH集群手动导入scm库

    一.手动导入 scm 库 背景:正常安装 cloudera-scm-server 时,安装 scm 库是通过脚本 /usr/share/cmf/schema/scm_prepare_database. ...

随机推荐

  1. python日期与日历Datetime和Calendar模块

    datetime模块 1.1 概述 datetime比time高级了不少,可以理解为datetime基于time进行了封装,提供了更多的实用的函数,datetime的接口更加的直观,更容易调用 1.2 ...

  2. LRU算法详解

    一.什么是 LRU 算法 就是一种缓存淘汰策略. 计算机的缓存容量有限,如果缓存满了就要删除一些内容,给新内容腾位置.但问题是,删除哪些内容呢?我们肯定希望删掉哪些没什么用的缓存,而把有用的数据继续留 ...

  3. #10051 Nikitosh 和异或

    Nikitosh 和异或 其实题意已经简单的不能再简单了,所以就不讲了. 因为题目中 \(1\leq l_1 \leq r_1 <l_2 \leq r_2\leq N\),所以显然对于最终答案, ...

  4. Java_多线程实现

    一个类两个接口 Tread类: 使用时继承Thread类 Runnable接口: 使用时实现Runnable接口 Callable接口: 使用时实现Callable接口 由于类只能单继承, 接口可以多 ...

  5. 管理机--Jumpserver由docker搭建

    一.环境准备 使用Centos7.0及以上版本,(网要好哦) 二.安装docker 1,下载,安装,启动 docker yum -y install docker         #安装docker ...

  6. excel导出csv包括逗号等的处理

    /** * @Title: trimRubbishChar * @Description: 导出的时候需要对一格的内容进行检查,看是否有非法字符,以免串行 * @Since: 2016年8月2日 下午 ...

  7. 使用css控制table的cellspacing和cellpadding属性

    HTML默认的表格样式之间有间隙,每次为了解决这些问题,总要在table标签里添加cellspacing和cellpadding,你是否也很厌倦这样的写法, 那么有没有对应的CSS属性能达到相同的效果 ...

  8. malloc/free与new/delete的区别(转)

    相同点:都可用于申请动态内存和释放内存 不同点:(1)操作对象有所不同.malloc与free是C++/C 语言的标准库函数,new/delete 是C++的运算符.对于非内部数据类的对象而言,光用m ...

  9. python3:文件读写+with open as语句(转)

    读写文件是最常见的IO操作.Python内置了读写文件的函数,用法和C是兼容的. 读写文件前,我们先必须了解一下,在磁盘上读写文件的功能都是由操作系统提供的,现代操作系统不允许普通的程序直接操作磁盘, ...

  10. Docker安装Oracle11g

    为什么使用docker安装oracle,因为自己搭建配置的话可能时间太久太繁琐等等原因,也因为docker实在太方便了 本文主要是使用docker-compose安装Oracle 11g,因为使用do ...