设为首页 收藏本站
查看: 1254|回复: 0

[经验分享] windows上oracle数据库导入导出数据

[复制链接]

尚未签到

发表于 2019-2-19 11:50:20 | 显示全部楼层 |阅读模式
  用Exp/Imp,Exp/Imp是oracle备份数据的两个命令行工具
exp导出      imp导入
1.本地数据库导入导出
1.导出
(运行---cmd中操作)
exp 用户名/密码@数据库实例名file=本地存放路径
例如: exp cmk/cmk@ORCL file=C:/jnjp.dmp  full=y
2.导入
imp 用户名/密码@数据库实例名file=本地数据库文件存放路径full=y   ignore=y
例如: imp cmk/cmk@orcl  file=E:\jnjp.dmp  full=y  ignore=y  
2.远程数据库导入导出
1.导出  
exp 用户名/密码@ip地址/数据库实例名file=本地存放路径
例如: exp cmk/cmk@192.168.10.1/orcl file=C:/jnjp.dmp   full=y
2.导入
imp 用户名/密码@ip地址/数据库实例名file=本地数据库文件存放路径full=y  
例如: imp  cmk/cmk@192.168.10.1/orcl file=C:/jnjp.dmp   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)

  • 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 将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:\exptest.dmptables=TABLE%  log=exp_test.log




运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-674411-1-1.html 上篇帖子: Windows 788-eduna的博客 下篇帖子: 如何使Windows显示文件扩展名
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表