加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

Oracle数据泵expdp/impdp

发布时间:2020-12-12 14:47:07 所属栏目:百科 来源:网络整理
导读:Oracle11g以后的新特性使得默认条件下在分配表空间时忽略空表,以减少表空间的资源占用,这样使得在使用Oracle的exp导出用户数据时就会忽略空表,这样就会造成数据的不完整,当然在使用exp导出数据时也不是没有办法,这个以前有提到过,在此就不做过多的赘述

Oracle11g以后的新特性使得默认条件下在分配表空间时忽略空表,以减少表空间的资源占用,这样使得在使用Oracle的exp导出用户数据时就会忽略空表,这样就会造成数据的不完整,当然在使用exp导出数据时也不是没有办法,这个以前有提到过,在此就不做过多的赘述了http://www.52php.cn/article/p-sozjcmsd-bha.html。使用这种方法是可以解决在使用exp导出用户数据时不会忽略空表,但是还有更为高效的办法就是使用expdp/impdp ――Oracle数据泵,来对Oracle数据进行导入导出,相比exp/imp而言expdp/impdp是更为高效的数据导入导出时使用的工具,当然在这里就expdp/impdp和exp/imp的区别简单的说一说。

和exp不同,在使用expdp导出数据时先要用DBA用户进入Oracle中执行一条指定备份路径后再授权可读写后,才能操作,具体操作步骤如下:

SQL>createorreplacedirectorydpdata1as'/data/backup/oracle_backup';

Directorycreated.

SQL>grantread,writeondirectorydpdata1tou01;

Grantsucceeded.

SQL>grantread,writeondirectorydpdata1tou02;

Grantsucceeded.

SQL>select*fromdba_directories;

这里dpdatal指定下要备份导出数据的路径,然后授权这个目录给要导出用户,这里要注意的是这个目录必须是Oracle用户的属组以确保文件权限可写入,在完成指定备份目录后就可以用expdp开始导出数据了,在使用expdp导出数据时会有import.log的日志文件生成,因为在这里是多个用户导出,我这里就指定下日志文件的文件名

[oracle@localhost~]$expdpu01/passwword_u01directory=dpdata1dumpfile=u01.dmplogfile=u01.log
expdpu02/password_u02directory=dpdata1dumpfile=u02.dmplogfile=u02.log

在导出后就会在指定的备份目录下生成备份文件和日志。

在导入的时候使用impdp导入,具体的使用方法同imp差不多,不过需要的是要指定备份目录,操作如下:

[oracle@localhostoracle_backup]$impdpu01/passwword_u01directory=dpdata1dumpfile=u02.dmpFULL=y
[oracle@localhostoracle_backup]$impdpu02/passwword_u02directory=dpdata1dumpfile=u02.dmpFULL=y

这样就导入完成了,不过在这里需要注意的一点是在使用impdp导入数据时,如果Oracle中没有创建相应的用户时,在导入后也会自动创建用户,所以在导入的时候需要注意千万不要把数据导错了,简单的Oracle数据泵expdp/impdp大致就是如此,其他还有按照表名、查询条件、全库导入导出的操作大致是一样,仅仅是需要修改几个参数,在此就不做过多的说明了

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读