Oracle数据导入与导出

一.前言:

oracle中提供了exp、imp命令来进行数据的备份与恢复,exp命令可以把数据从远程数据库服务器导出到本地的dmp文件,imp命令可以把dmp文件从本地导入到远处的数据库服务器中。 利用这个功能可以构建两个相同的数据库,一个用来测试,一个用来正式使用。


二.使用

1. exp命令有三种导出方式(数据库、用户、表)

(1)完全导出:(一般不使用该方式)

     exp hdfs/123456@orcl  file=d:\database.dmp  log=d:\database.log  full=y

     将数据库orcl完全导出(登录用户名是hdfs、密码是123456),导出到d:\database.dmp中;

(2)导出用户:(常用)

     exp hdfs/123456@orcl  file=d:\database.dmp  log=d:\database.log  owner=hdfs

     将数据库orcl中的用户hdfs导出,导出到d:\database.dmp中;

     注意:full方式可以备份所有用户的数据库对象,包括表空间、用户信息等,owner=XX只能备份指定用户的对象,其他用户下的就不备份了,

   exp中full=yowner=XX是不能同时使用的。

(3)导出表:(了解)

     exp hdfs/123456@orcl  file=d:\database.dmp  log=d:\database.log   tables=(b_role,b_users)

     将数据库orcl 中用户hdfs的b_role、b_users表导出,导出到d:\database.dmp中;

     注意:tables=XX 表示备份相关表,不能同时和ownerfull使用(否则会抛出EXP-00026:指定了冲突模式)。


2. imp命令有三种导入方式(数据库、用户、表)

(1)完全导入:(一般不使用该方式)

    imp hdfs/123456@orcl  file=d:\database.dmp  log=d:\database.log 

    将d:\database.dmp中的数据导入到数据库orcl中;


注意:导入数据时,有可能会报错,主要有以下3个原因:

  a)导入的对象(表、视图、索引等)原本用户就不属于当前连接的hdfs用户;

  b)导入的对象(表、视图、索引等)在orcl数据库的hdfs用户下已经存在(假设导出对象的原本用户属于当前连接的hdfs用户);

  c)导入的对象(表、视图、索引等)的原本用户,在该orcl数据库中不存在;

  对于以上问题,我们可以使用2个办法:

  a)将所有对象导入到指定的用户下(也就是下面的 "导入用户” )

  b)忽略导入数据:imp hdfs/123456@orcl  file=d:\database.dmp  log=d:\database.log   ignore=y(因为有的对象已存在,所以这里就忽略导入)


(2)导入用户:(常用)

    imp hdfs/123456@orcl  file=d:\database.dmp  log=d:\database.log  fromuser=hdfs_old  touser=hdfs

    将d:\database.dmp中的原先用户,导入到数据库orcl中的hdfs用户中;

    其中:fromuser=hdfs_old为database.dmp文件中原先的用户,touser=hdfs为导入对象的新用户;


(3)导入表:(了解)

    imp  hdfs/123456@orcl  file=d:\database.dmp  log=d:\database.log   tables=(b_role,b_users)

    将d:\database.dmp中的表b_role,b_users,导入到数据库orcl中的hdfs用户中;


基本上以上列举的导入导出以及够用了,大多数情况都是要先所有的表彻底删除后,在进行导入。

参考网址:http://blog.itpub.net/21614165/viewspace-766937

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值