oracle数据库的导入导出
wptr33 2025-01-12 19:03 66 浏览
今天给大家写了一篇关于数据泵导出导出的文章,大家可以看看,一起学习学习,并且附带了集中本人在做的过程中遇到的问题,也一起给大家分享出来了。
一、 数据泵实现数据导入导出的步骤
注意:
红色标记部分为可按需求修改部分,导出部分表时可在"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,但是这个表空间又被人删除了。于是便有了这样一个案例。
相关推荐
- redis的八种使用场景
-
前言:redis是我们工作开发中,经常要打交道的,下面对redis的使用场景做总结介绍也是对redis举报的功能做梳理。缓存Redis最常见的用途是作为缓存,用于加速应用程序的响应速度。...
- 基于Redis的3种分布式ID生成策略
-
在分布式系统设计中,全局唯一ID是一个基础而关键的组件。随着业务规模扩大和系统架构向微服务演进,传统的单机自增ID已无法满足需求。高并发、高可用的分布式ID生成方案成为构建可靠分布式系统的必要条件。R...
- 基于OpenWrt系统路由器的模式切换与网页设计
-
摘要:目前商用WiFi路由器已应用到多个领域,商家通过给用户提供一个稳定免费WiFi热点达到吸引客户、提升服务的目标。传统路由器自带的Luci界面提供了工厂模式的Web界面,用户可通过该界面配置路...
- 这篇文章教你看明白 nginx-ingress 控制器
-
主机nginx一般nginx做主机反向代理(网关)有以下配置...
- 如何用redis实现注册中心
-
一句话总结使用Redis实现注册中心:服务注册...
- 爱可可老师24小时热门分享(2020.5.10)
-
No1.看自己以前写的代码是种什么体验?No2.DooM-chip!国外网友SylvainLefebvre自制的无CPU、无操作码、无指令计数器...No3.我认为CS学位可以更好,如...
- Apportable:拯救程序员,IOS一秒变安卓
-
摘要:还在为了跨平台使用cocos2d-x吗,拯救objc程序员的奇葩来了,ApportableSDK:FreeAndroidsupportforcocos2d-iPhone。App...
- JAVA实现超买超卖方案汇总,那个最适合你,一篇文章彻底讲透
-
以下是几种Java实现超买超卖问题的核心解决方案及代码示例,针对高并发场景下的库存扣减问题:方案一:Redis原子操作+Lua脚本(推荐)//使用Redis+Lua保证原子性publicbo...
- 3月26日更新 快速施法自动施法可独立设置
-
2016年3月26日DOTA2有一个79.6MB的更新主要是针对自动施法和快速施法的调整本来内容不多不少朋友都有自动施法和快速施法的困扰英文更新日志一些视觉BUG修复就不翻译了主要翻译自动施...
- Redis 是如何提供服务的
-
在刚刚接触Redis的时候,最想要知道的是一个’setnameJhon’命令到达Redis服务器的时候,它是如何返回’OK’的?里面命令处理的流程如何,具体细节怎么样?你一定有问过自己...
- lua _G、_VERSION使用
-
到这里我们已经把lua基础库中的函数介绍完了,除了函数外基础库中还有两个常量,一个是_G,另一个是_VERSION。_G是基础库本身,指向自己,这个变量很有意思,可以无限引用自己,最后得到的还是自己,...
- China's top diplomat to chair third China-Pacific Island countries foreign ministers' meeting
-
BEIJING,May21(Xinhua)--ChineseForeignMinisterWangYi,alsoamemberofthePoliticalBureau...
- 移动工作交流工具Lua推出Insights数据分析产品
-
Lua是一个适用于各种职业人士的移动交流平台,它在今天推出了一项叫做Insights的全新功能。Insights是一个数据平台,客户可以在上面实时看到员工之间的交流情况,并分析这些情况对公司发展的影响...
- Redis 7新武器:用Redis Stack实现向量搜索的极限压测
-
当传统关系型数据库还在为向量相似度搜索的性能挣扎时,Redis7的RedisStack...
- Nginx/OpenResty详解,Nginx Lua编程,重定向与内部子请求
-
重定向与内部子请求Nginx的rewrite指令不仅可以在Nginx内部的server、location之间进行跳转,还可以进行外部链接的重定向。通过ngx_lua模块的Lua函数除了能实现Nginx...
- 一周热门
-
-
C# 13 和 .NET 9 全知道 :13 使用 ASP.NET Core 构建网站 (1)
-
因果推断Matching方式实现代码 因果推断模型
-
git pull命令使用实例 git pull--rebase
-
git pull 和git fetch 命令分别有什么作用?二者有什么区别?
-
面试官:git pull是哪两个指令的组合?
-
git 执行pull错误如何撤销 git pull fail
-
git fetch 和git pull 的异同 git中fetch和pull的区别
-
git pull 之后本地代码被覆盖 解决方案
-
还可以这样玩?Git基本原理及各种骚操作,涨知识了
-
git命令之pull git.pull
-
- 最近发表
- 标签列表
-
- git pull (33)
- git fetch (35)
- mysql insert (35)
- mysql distinct (37)
- concat_ws (36)
- java continue (36)
- jenkins官网 (37)
- mysql 子查询 (37)
- python元组 (33)
- mybatis 分页 (35)
- vba split (37)
- redis watch (34)
- python list sort (37)
- nvarchar2 (34)
- mysql not null (36)
- hmset (35)
- python telnet (35)
- python readlines() 方法 (36)
- munmap (35)
- docker network create (35)
- redis 集合 (37)
- python sftp (37)
- setpriority (34)
- c语言 switch (34)
- git commit (34)