oracle数据库导入导出方法

oracle数据库导入导出方法

Oracle Database 10g以后引入了最新的数据泵(Data Dump)技术,使DBA或开发人员可以将数据库元数据(对象定义)和数据快速移动到另一个oracle数据库中。
数据泵导出导入(EXPDP和IMPDP)的作用
 1、实现逻辑备份和逻辑恢复。
 2、在数据库用户之间移动对象。
 3、在数据库之间移动对象
 4、实现表空间搬移。

数据泵导出导入与传统导出导入的区别:
 
在10g之前,传统的导出和导入分别使用EXP工具和IMP工具,从10g开始,不仅保留了原有的EXP和IMP工具,还提供了数据泵导出导入工具EXPDP和IMPDP.使用EXPDP和IMPDP时应该注意的事项;
 
EXP和IMP是客户段工具程序,它们既可以在客户端使用,也可以在服务器段使用。
 
EXPDP和IMPDP是服务端的工具程序,他们只能在ORACLE服务端使用,不能在客户端使用
 
IMP只适用于EXP导出文件,不适用于EXPDP导出文件;IMPDP只适用于EXPDP导出文件,而不适用于EXP导出文件。
 
 
今天我在导入同事给我的数据文件时,总是报IMP-00038错误,提示,无法转换为环境字符集句柄,造成这种错误的原因一般是数据库版本不匹配,但是我们使用的都是oracle11g,就排除了这种可能。最后发现原因是他是使用数据泵导出的数据文件,而我使用传统imp命令导入是不可以的,后续改为使用impdp数据泵导入成功。
 
下面是我使用数据泵导入数据文件的完整过程:
 
1、使用system用户登录数据库,创建新用户usertest(新建用户时用户名最好和数据文件导出时的用户名相同),表空间可以使用系统默认的也可以自己新建一个表空间。sql代码如下:
 
新建用户使用oracle默认表空间:
create user usertest identified by usertest; 
 
新建表空间:
create tablespace user_all 
datafile 'D:/dev/oracle/tablespace/user_all.dbf'
size 300M   
autoextend on   
next 50M   
maxsize unlimited 
 
新建用户(设置默认表空间):
create user usertest identified by usertest default tablespace user_all;
 
2、对新建的用户赋权限,dba、connect、resource。sql代码如下:

grant connect, resource,dba to usertest;
 
3、为数据库导入导出,新建目录文件 如dumpdir
 
create directory 目录名称 as '数据库服务器上的一个目录',如:
create directory dumpdir as 'd:\服务器目录名';
将导入或导出的文件放在这个目录下
 
4、为此用户的导入导出目录赋读写权限
grant read,write on directory dumpdir to usertest;

 
5、导出及导入
以SID=orcl,导出dmp的账号为usertest,导入dmp的账号为usertest为例。

 
若将数据从sfz中导出:
expdp usertest/usertest@orcl directory=dumpdir  dumpfile=导出文件名

 
导入到usertest中:
impdp usertest/usertest@orcl directory=dumpdir  dumpfile=导出文件名.dmp
 
导入导出用户名最好相同,用户名不同时,还需要做个映射
 
remap_schema=test:usertest 

 
注意在使用本地数据库时,要启动以下oracle服务:
 
OracleOraDb11g_home1TNSListener
OracleServiceORCL
如果只是连接远程服务器上的数据库,仅使用PL/SQL工具,那么可以把服务全停,这样能省点内存。

原文链接:

https://www.cnblogs.com/whsa/p/3975817.html

======================================exp/imp=========================================

  一、将服务器上的oracle数据库导出

  (1)方法一:如果在本地能远程上服务器,且在服务器上安装了PL/SQL Developer 数据库图形化工具,在服务器上,进入cmd命令窗口

     输入:exp userid=userName/userPass@orcl  owner=用户名  file=d:/daochu.dmp

    说明:userName、userPass为具有DBA权限的用户,orcl为服务器数据库的SERVICE_NAME,一般为orcl; 为数据库的服务导出哪个用户的表,改变owner后的用户名即可;file为文件导出路径、名称。

(2)方法二:在本地cmd命令窗口下进行操作(需要知道服务器的ip地址)

    输入: exp userid=userName/userPass@服务器ip:1521/orcl owner=用户名  file=d:/daochu.dmp

 

  二、导入到本地oracle数据库中去

(1)、在本地安装好oracle数据库

(2)、建立用户test(用户自定义),默认表空间

 

         create user test identified by test

        //赋予test用户DBA权限
         grant dba to test;

(3)、导入到本地Oracle数据库
   在cmd下执行以下命令,将导出的daochu.dmp文件导入到本地oracle数据库
   输入:imp test/test@orcl  file=d:/daochu.dmp  fromuser=用户名  touser=test 

原文链接:

https://blog.csdn.net/u011159900/article/details/59110024

 

 

转载于:https://my.oschina.net/u/3083563/blog/2208998

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值