今天给大家写了一篇关于数据泵导出导出的文章,大家可以看看,一起学习学习,并且附带了集中本人在做的过程中遇到的问题,也一起给大家分享出来了。

一、 数据泵实现数据导入导出的步骤

注意:

红色标记部分为可按需求修改部分,导出部分表时可在"Expdp [用户名A]/[密码]@[数据库名]"后跟"TABLES=需要导出的部分表的表名"。

例:不同用户不同表空间的导出导入

(一)导入导出需求

1、导出用户表

用户:ysgrp 密码: ysgrp2018 IP: 192.168.2.2/ys

需求: 把 CWHS、DEMO 开头的表及数据导出导入到 下面用户中

2、导入用户表

用户:nkys 密码: nkys IP: 192.168.2.3/orcl

(二)数据泵方式的导出

1、用sysdba用户登录数据库

sqlplus /nolog

conn /as sysdba

2、创建目录[dump_dir]

Create directory dump_dir as 'd:ysgrp';

3、给dump_dir目录下的用户ysgrp授权

Grant read,write on directory dump_dir to ysgrp;

4、按照需求选择要导出的表

select table_name from user_tables where (table_name like 'CWHS%' OR table_name like 'DEMO%')and table_name not in ('DEMO_DW_RYSL','DEMO_FXDTJK');

5、导出表(按需求总共有71张表需要导出,则在输入导出命令和用户名密码后的"TABLES="后面跟需要导出的表名,表名之间用逗号隔开,其后跟导出文件的名称,目录名称和日志名称。)

Expdp ysgrp/ysgrp2018@192.168.2.2/ys TABLES=CWHS_CZZF,CWHS_CZZF_TEMP dumpfile=ysgrp.dmp DIRECTORY=dump_dir logfile=ysgrp.log;

(三)数据泵方式的导入

1、在目标库用sysdba用户登录数据库

sqlplus /nolog

conn /as sysdba

2、创建目录[dpdata1]

Create directory dpdata1 as '/home/nkys';

3、给dpdata1目录下的用户nkys授权

Grant read,write on directory dpdata1 to nkys;

4、导入数据(REMAP_SCHEMA=数据导出用户名:数据导入用户名;)

impdp nkys/nkys@192.168.2.3/orcl directory= dpdata1 dumpfile=' ysgrp.dmp ' REMAP_TABLESPACE= ysgrp: nkys REMAP_SCHEMA= ysgrp: nkys logfile= dpdata1.log ignore=y

二、使用PL/SQL Developer导入导出数据库

1、导出数据库对象

在PL/SQL Developer的菜单Tools=>Export User Objects中出来一个对话框界面,然后框选要导出的Oracle 数据库对象,包括表,序列,存储过程,视图,函数等等,并指定导出的文件名称,如下操作。

选择需要导出的表及导出文件的存放路径。

2、导出表数据

导出表结构和对象后,我们下一步就是导出数据库的表数据,PL/SQL Developer工具支持导出数据到PL/SQL数据库脚本中,如下所示。这样导出的脚本,我们可以在PL/SQL Developer工具导入。

选择上一步导出表结构的表数据:

3、 导入表结构及数据

导入数据库表结构和表数据可以直接运用PL/SQL Developer的工具菜单下的导入表选框,选择SQL插入,勾选使用命令窗口选择刚刚导出的表结构进行表结构的导入。如下所示。

出现SQL>说明数据结构导入成功,接下来用同样的方式导入表数据:

三、用imp/exp导入导出数据库

注意:

红色标记部分为可按需求修改部分。

四、oracle库表删除注释和恢复的步骤

(一)、先备份字段注释.以便以后dmp数据有注释。

plsql执行: select 'comment on column '||t.table_name||'.'||t.column_name||' is '''||t.comments||''';' from user_col_comments t;

2. 2 2. 点获取所有行,复制所有查询出的行.保存到新建的txt.可用于恢复。

(二)、删除所有注释。

plsql执行: select 'comment on column '||t.table_name||'.'||t.column_name||' is '''';' from user_col_comments t;

点获取所有行,复制所有查询出的行. 执行复制出的所有语句.测试在数据过大的情况plsql下容易编译卡死.在sqldeveloper无此情况。

表名注释的替换更改

select 'comment on table '||table_name||' is '||''''||comments||''''||';' from user_tab_comments

where comments is not null;

表中字段的替换更改

select 'comment on column ' || TABLE_NAME || '.' || COLUMN_NAME || ' is ' ||''''||

COMMENTS ||''''|| ';'

from user_col_comments

where comments is not null;

七、可能会出现的错误

(一)数据泵导入导出可能出现的错误

错误一:ORA-44002: 对象名无效

ORA-39065: DISPATCH 中出现意外的主进程异常错误;ORA-44002: 对象名无效

Windows 平台错误提示:

Linux平台错误提示:

解决方法:

cd $ORACLE_HOME/rdbms/admin

SQL> @catmet2.sql

SQL> @utlrp.sql

错误二:ORA-39006

使用expdp/impdp时遭遇ORA-39006: internal error;ORA-39213: Metadata processing is notavailable错误

[oracle@DB-Server backup]$ impdp frnt/frnt directory=dum_dir dumpfile=20120420.FRNT_02.dmp tablespaces=TBS_TR_DATA;

Import: Release 10.2.0.1.0 - 64bit Production on Wednesday, 25 April, 2012 14:41:48

Copyright (c) 2003, 2005, Oracle. All rights reserved.

Connected to: Oracle Database 10g Enterprise Edition Release 10.2.0.1.0 - 64bit Production

With the Partitioning, OLAP and Data Mining options

ORA-39006: internal error

ORA-39213: Metadata processing is not available

解决方法:

错误原因如下所示,因为Data Pump不能使用Metadata API, 这个是因为XSL stylesheets 没有正确设置缘故。需要以SYSDBA执行dbms_metadata_util.load_stylesheets

执行:

SQL>exec dbms_metadata_util.load_stylesheets

再执行导出语句

错误三:ORA-39002、ORA-39070、ORA-29283 、ORA-06512、ORA-29283

解决方法:

出现这个错误,需要检查DIRECTORY目录,创建DIRECTORY时,ORACLE并不检查操作系统目录是否已经存在

首先检查DIRECTORY目录DUMP_TEST对应的DIRECTORY_PATH,然后检查操作系统下,验证该目录是否存在。

结果检查发现该目录被删除了,创建该目录即可解决问题。

另外一种情况,如果创建DIRECTORY目录时,出现了换行,也会出现上面错误信息,这种错误玩玩很难发现,非常折腾人。所以需要非常细心。

SQL> create directory DUMP_TEST as '/jkfile/klbtmp/';

错误四:ORA-31613、ORA-39109

解决方法:

主要是etl账号缺少exp_full_database 权限,给etl账号授予exp_full_database 权限后,上述问题解决。

错误五:LRM-00101

etl@NMS_ODS_NDB1[/etl1_cx/etl]expdp etl/sunrise@wgods1 dumpfile=DM.TM_ALARM_LOG.dmp directory=DUMP_DIR tables=DM.TM_ALARM_LOG query='DATE_CD >=20121201 AND DATE_CD <=20130131';

LRM-00101: unknown parameter name '>'

解决办法:

etl@NMS_ODS_NDB1[/etl1_cx/etl]expdp etl/sunrise@wgods1 dumpfile=DM.TM_ALARM_LOG.dmp directory=DUMP_DIR tables=DM.TM_ALARM_LOG query="DATE_CD >=20121201 AND DATE_CD <=20130131";

错误六: LRM-00121

LRM-00121: 'DATA_ONLY' is not an allowable value for 'compression'。如下所示:

etl@NMS_ODS_NDB1[/etl1_cx/etl]#expdp etl/sunrise@wgods1 dumpfile=ref.dmp directory=DUMP_DIR dumpfile=DM.TM_ALARM_LOG201212.dmp tables=DM.TM_ALARM_LOG COMPRESSION=DATA_ONLY query='DATE_CD >=20121201 AND DATE_CD <=20130131';

首先查看EXPDP工具的版本,如下所示:

etl@NMS_ODS_NDB1[/etl1_cx/etl]#expdp version

请注意,在ORACLE 10g下 COMPRESSION只有METADATA_ONLY和NONE两个选项,ORACLE 11g下才有DATA_ONLY选项。所以报如上错误。所以在使用前,请注意一下EXPDP工具的版本。

错误七: ORA-31626 、ORA-31637 、ORA-06512 、ORA-06512 、ORA-39080 、ORA-06512 、ORA-06512 、ORA-00832:

[oracle@DB-Server]$ expdp system/***** TABLES=INVENRTY.INV_STK_HD dumpfile=INV_STK_HD.dmp logfile=1.log DIRECTORY=CUR_DUMP_DIR

解决办法:参考数据导出Expdp 导数错误 ORA-00832

错误八:ORA-31626 、ORA-31633 、ORA-06512 、ORA-06512 、ORA-00959:

解决方法:

本来有一个TOOLS的表空间,指定了SYSTEM用户的默认表空间为TOOLS,但是这个表空间又被人删除了。于是便有了这样一个案例。

cvs数据导入工具 oracle_oracle数据库的导入导出相关推荐

  1. oracle数据插入覆盖,oracle数据库覆盖导入

    oracle数据库备份(导入导出dmp)_IT/计算机_专业资料.包括远程连接 ... oracle数据库导入导出命令_计算机软件及应用_IT/计算机_专业资料.Oracle 数据导入导出 imp/e ...

  2. 600 imp oracle_oracle数据库的导入导出(imp和exp)

    前提是源库和目标库的user和tablespace一样 ------------------------------------------------------------------------ ...

  3. matlab导入桌面excel数据库,matlab导入excel数据_excel怎么导入网络上的数据?_excel导入网络数据...

    网络上的数据怎么导到excel中.有方法是直接复制然后粘贴到excel中,但是网络上直接复制过来的,可能不能直接进去下一步编辑.因为复制过来的每个词后面都有空格,是不能进行直接计算,连最基本的求和都不 ...

  4. mysql转储导入错误_数据库MYSQL导入SQL文件时错误的解决方法(2种)

    从服务器数据库用navicate导出的.sql文件后再用navicate导入到本地的数据库中会出现若干条记录的错误: [Err] 1064 – You have an error in your SQ ...

  5. mysql数据库导入操作_MySQL数据库的导入方法

    问题 如何导入MySQL数据库 解决方案 1. 概述 MySQL数据库的导入,有两种方法: 1) 先导出数据库SQL脚本,再导入: 2) 直接拷贝数据库目录和文件. 在不同操作系统或MySQL版本情况 ...

  6. 6.(Mysql数据管理相关)连接MYSQL,修改密码,增加新用户,数据库相关命令,表操作相关命令,数据相关命令,数据库sql导入和导出,备份数据库,查看不到mysql数据库的解决办法

     mysql安装完之后,登陆后发现只有两个数据库:mysql>show databases; +--------------------+ | Database           | +- ...

  7. php网站mysql数据库导入工具_phpstudy通过phpMyAdmin导入mysql数据库方法

    不是我们作品的用户,也可联系上面QQ提供有偿人工指导服务 导入Mysql数据库只用导一次,以后项目出问题了,也不用操作数据库了.但是运行程序的时候一定保证phpstudy是启 动状态. 1.a.把电脑 ...

  8. phpexcel 将excel数据导入到mysql数据库_phpexcel导入excel到mysql数据库(示例)

    session_start(); header("Content-type:text/html;charset:utf-8"); //全局变量 $succ_result=0; $e ...

  9. mysql 数据库 导入兼容_mysql数据库的导入和导出

    一.导出: 用mysqldump命令行 命令格式 mysqldump -u 用户名 -p 数据库名 > 数据库名.sql 范例: mysqldump -u root -p abc > ab ...

最新文章

  1. oracle手工快照,创建oracle快照的步骤
  2. android studio安装在其他盘,Android Studio配置移动到D盘(亲测)
  3. 项目管理实战之团队管理 (转)
  4. LeetCode Algorithm 83. 删除排序链表中的重复元素
  5. 前端获取当前url路径
  6. 伪共享和缓存行填充,Java并发编程还能这么优化!
  7. 华为面试分配_什么时候不做面试分配
  8. Xshell利用密钥远程登录Linux
  9. java库房仓库管理系统_Java学员作品-仓库管理系统
  10. 内网渗透系列:内网隧道之DNS隧道
  11. 【提前批】【第二批】CUHK CSE 面经2022.6.17
  12. 基于Android的万豪酒店APP设计与实现
  13. 对实际电流源中内阻变化的简单分析
  14. springboot为什么返回Whitelabel Error Page
  15. EBS 报表开发:标准报表Text输出改为XML输出
  16. 联想air15和联想小新15有什么区别
  17. Tomcat 打印日志让你事半功倍
  18. 时隔多年,我胡汉三又回来了
  19. 学计算机大一入实验室,上大一就可以做科研的上科大:充分尊重第一志愿,一半新生学计算机...
  20. Java高级程序员面试题

热门文章

  1. activity状态的保存和恢复
  2. [转]JSP中常见的Tomcat报错错误解析(一)
  3. poj2125最小点权覆盖
  4. 使用 Repeater方式和完全静态页面使用AJAX读取和提交数据
  5. C#中IListT与ListT的区别感想
  6. Android系统自带AEC/AGC/NC的demo
  7. Android解包命令:unpackbootimg与打包命令:mkbootimg使用
  8. 函数指针 回调函数 面向对象风格的C语言
  9. Erlang初学:Erlang的一些特点和个人理解总结
  10. Rtsp之信令交互流程