orcal数据泵导出导入

本文详细介绍了Oracle数据库中数据泵导出导入工具EXPDP和IMPDP的使用方法,包括创建用户、分配权限、创建目录文件等步骤,并提供了解决IMP-00038错误的具体案例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在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:\oracle\product\10.2.0\oradata\orcl\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:\服务器目录名'; --如d:\dpdump
将导入或导出的文件放在这个目录下


修改这个路径 用create or replace:如
create or replace directory DUMPDIR as 'D:\oracle\product\10.2.0\admin\orcl\dpdump'
 
4、为此用户的导入导出目录赋读写权限
grant read,write on directory dumpdir to usertest;
 
5、导出及导入
以SID=orcl,导出dmp的账号为usertest,导入dmp的账号为usertest为例。
 
若将数据从sfz中导出:
expdp usertest/usertest@orcl directory=dumpdir  dumpfile=导出文件名 (transform=oid:n --transform取值oid:n的含义就是对oid信息不进行加载,重新进行生成    version=10.2.0.3.0  --设置版本号 导出需)                                          


 具体实例:
--清空库
DROP USER usertest CASCADE;
--创建用户表空间
CREATE USER usertest IDENTIFIED BY usertest DEFAULT TABLESPACE user_all ;
--分配权限
GRANT DBA TO usertest ;
导入到usertest中:mipdp usertest/usertest@orcl directory=dumpdir  dumpfile=导出文p
件名.dm 
导入
导出用户名最好相同,用户名不同时,还需要做个映射
 remap_schema=test:usertest 
 
注意cl在使用本地数据库时,要启动以下orae服务:


 OracleOraDb11g_home1TNSListener
OracleServiceORCL
 
如果SQ只是连接远程服务器上的数据库,仅使用PL/L工具,se那么可以把服务全停,这样能省点内存。


lect * from dba_directories
SELECT * FROM V$SESSION WHERE USERNAME='BJDLCGDB';


DROP USER BJDLCGDB CASCADE;

CREATE USER BJDLCGDB IDENTIFIED BY BJDLCGDB DEFAULT TABLESPACE BJDLCGDB;

GRANT DBA TO BJDLCGDB;

打开cmd
先登录sqlplus  /nolog

conn/as sysdba

再打开一个cmd命令窗口

在切换到cmd入-在数据泵导对况IST象已存在的情S下执行导入 TABLE_EX_ACTION=append CONTENT=data_only
impdp BJDLCGDB/BJDLCGDB dumpfile=YUF20170418.DMP directory=DATA_PUMP_DIR 
数据泵导入 不同用户数据迁移执ser 重新建立用户 再/行导入语句
impdp upassword dumpfile=temp.dmp directory=dump remap_tablespace=[old_table_space]:[new_table_space] ?; old是指server1上的ta机器blee_naspacme,new是指serer2
v--上的---------------------------------------------
数据泵导出几张表mt/1或者部分数据
expdp h23456 dumpfile=hmtdb20130301.dmp directory=hmt_dir tables = DATES, DIM_CITY_PROVINCE, DIM_DOMAIN_TYPE, DIM_DOMAIN_TYPE_R, DURATIONS,HOURS
### Oracle 数据库导入导出工具 `impdp` 使用方法 #### 工具概述 Oracle 提供了多种用于数据导入导出的工具,其中 `Data Pump` 是一种高效的企业级解决方案。`impdp` 和 `expdp` 分别是 `Data Pump Import` 和 `Data Pump Export` 的命令行接口[^1]。 #### 基本语法 `impdp` 的基本语法如下: ```bash impdp username/password@database options... ``` 这里的关键参数包括但不限于: - **DIRECTORY**: 指定目录对象名称,该对象定义了操作系统路径。 - **DUMPFILE**: 指定要加载的数据泵转储文件名。 - **TABLES**: 列举需要处理的具体表列表。 - **SCHEMAS**: 定义待操作模式的名字集合。 - **REMAP_SCHEMA**: 将源架构映射到目标架构。 - **LOGFILE**: 记录日志的位置及文件名。 #### 实际案例展示 假设有一个名为 `my_dbdata` 的目录对象指向 `/u01/app/oracle/dumpfiles/`, 并存在一个叫做 `tablespace.dmp` 的转储文件,则可以执行以下命令来完成特定表空间内所有对象及其关联元数据的恢复工作: ```bash impdp system/system DIRECTORY=my_dbdata DUMPFILE=tablespace.dmp TABLESPACES=users LOGFILE=import.log ``` 对于只想迁移某些指定表格的情况,可以通过设置 `TABLES` 参数实现更精细控制: ```bash impdp hr/hr DIRECTORY=dumpdir DUMPFILE=schema_tables.dmp TABLES=(employees,jobs) REMAP_SCHEMA=hr:new_hr ``` 此命令会把来自 HR 架构下的 EMPLOYEES 及 JOBS 表迁移到 NEW_HR 下面去[^5]。 为了确保权限正确无误,在实际环境中可能还需要调整相应文件夹访问属性,比如通过 Linux 系统中的 chown 命令更改属组关系[^3]: ```bash chown -R oracle:oinstall /path/to/export/files/ ``` 需要注意的是,`impdp` 主要是用来读取由 `expdp` 创建出来的 `.dmp` 文件,而不能直接解析旧版 `EXP` 所产生的输出结果[^2]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值