【Oracle】Oracle导入导出dmp文件

news2024/11/24 22:40:38

文章目录

  • 前言
  • 一、什么是dmp?
  • 二、imp/impdp、exp/expdp对比及示例
    • 1.区别
    • 2.imp/impdp对比及示例
      • a. imp
      • b. impbp
    • 3.exp/expdp对比及示例
      • a. exp
      • b.expdp
    • 3.其他事项
  • 三、执行导入导出前置条件
    • 1.创建角色并授权
    • 2.创建目录映射


前言

在工作中,经常会遇到需要备份库,库表迁移的场景,对于oracle会使用dmp文件进行数据迁移和备份。基于一次迁移数据库的经历,整理记录dmp相关知识点,供后续工作参考使用。


一、什么是dmp?

dmp是"Data Pump"的缩写,它是Oracle独有的一种数据导入导出文件格式。.dmp文件是一种数据库导出文件的扩展名,通常用于存储数据库中的表、数据、视图等对象的结构和内容。是一种特定数据库系统的二进制信息,因此不能直接用文本编辑器打开。

●.dmp文件一般包含数据定义语言(DDL)和数据操作语言(DML)。具体来说,DDL是用来定义数据库对象,例如表、视图、用户等等;DML则是用来操作这些对象,例如插入、删除、更新数据等。常用来进行数据库迁移或者备份操作。

●其他数据库也有类似备份文件,比如MySQL数据库使用.sql文件或者.dump文件来表示数据库导出文件,而SQL Server数据库使用.bak文件来表示备份文件。

二、imp/impdp、exp/expdp对比及示例

imp/exp(Oracle导入导出实用程序)是使用传统的导出技术,而impdp/expdp(数据泵导入实用程序)是使用Oracle Data Pump技术。Data Pump是Oracle在10g版本中引入的高性能、可扩展的导入导出工具,即 Oracle 10g 之前的版本不可以使用 impdp/expdp。

1.区别

●imp和exp是传统的导入和导出工具,而impdp和expdp是数据泵工具,采用了新的架构和方法。

●imp和exp是基于基于二进制文件的,而impdp和expdp则是使用数据泵作业来执行数据移动操作,可以提供更高的性能和扩展性。

●imp和exp不支持在分布式环境中执行,而impdp和expdp可以在分布式环境中执行。

●数据泵通常指的是一种高性能的数据导入和导出工具,用于在数据库系统中进行快速的数据迁移和加载操作。数据泵工具能够提供比传统的导入导出工具更快速、更灵活的数据传输方式,通常支持并行处理、大容量数据传输和高性能加载等特点。

2.imp/impdp对比及示例

在这里插入图片描述

a. imp

可通过 imp help=y 命令查询相关参数

  • imp常用参数说明,可以根据需要指定不同的参数来控制导入的方式和内容。
参数使用说明
TOUSER指定要导入数据的用户名。
FROMUSER指定导入数据来自的用户名。
FILE指定要导入的文件路径和名称。例如,FILE=/path/to/import.dmp。
IGNORE指定是否忽略导入过程中遇到的错误。可以是Y或N。
INDEXES指定是否导入索引。可以是Y或N。
ROWS控制是否导入表中的行数据。可以是Y或N。
DATA_ONLY指定只导入数据,不包括对象定义。可以是Y或N。
IGNORECASE指定导入时是否忽略大小写。可以是Y或N。
FULL指定导入前先删除现有对象。可以是Y或N。
LOG指定导入操作的日志文件路径和名称。例如,LOG=/path/to/import.log。
BUFFER指定读取导入文件时的缓冲区大小。
REMAP_SCHEMA指定要将导入的对象映射到的新模式名。
REMAP_TABLESPACE指定要将导入的表空间映射到的新表空间名。
TABLES指定要导入的特定表。举例:IMP SCOTT/TIGER IGNORE=Y TABLES=(EMP,DEPT) FULL=N(or TABLES=(T1:P1,T1:P2) 表分区可用)
  • 命令格式:
imp 用户名/密码@数据库实例 FILE=导入文件的路径.dmp FROMUSER=源用户名 TOUSER=目标用户名
  • 命令示例:
--windows环境下
imp username/password@SERVICENAME:1521 file=e:\temp.dmp rows=y
log=E:/test/dmp/kf_workflow_0512.log full = y;
-linux环境路径进行替换

b. impbp

可通过 impbp help=y 命令查询相关参数

  • impbp常用参数说明,可以根据需要指定不同的参数来控制导入的方式和内容。
参数使用说明
ATTACH指定是否附加到正在运行的 impdp 作业。
DIRECTORY指定导入和导出文件所在的目录对象。
DUMPFILE指定要导入的数据泵文件名。
REMAP_DATAFILE指定要将源数据文件映射到的目标数据文件。
REMAP_SCHEMA指定要将源模式映射到的目标模式。
REMAP_TABLESPACE指定要将源表空间映射到的目标表空间。
TABLE_EXISTS_ACTION对于已存在的表,指定要采取的操作(SKIP、APPEND、TRUNCATE、REPLACE)。
TRANSFORM指定要应用的数据转换选项。
CONTENT指定要导入的对象类型(ALL、DATA_ONLY、METADATA_ONLY)。
PARALLEL指定并行执行导入作业的程度。
LOGFILE指定导入操作的日志文件名。
INCLUDE/EXCLUDE指定要导入或排除的对象。
QUERY指定导入时使用的查询条件。For example, QUERY=employees:“WHERE department_id > 10”.
  • 命令格式:
--命令参考
impdp 用户名/密码@数据库实例 DIRECTORY=目录名称 DUMPFILE=导入文件的名称.dmp REMAP_SCHEMA=源用户名:目标用户名
--举例
impdp user/password@SID DIRECTORY=DMPDATA DUMPFILE=fileName.dmp remap_tablespace=um_dev:um remap_schema=u_um_dev:u_um

参数说明:

  1. user/password@SID 用户名/用户密码@数据库实例;
  2. directory=dmpdata 导入的目录,DMPDATA为数据库虚拟路径(参考目录三中的目录映射),即导入dmpdata下的文件也就是’/data/u01/dmpdata/';
  3. dumpfile=filename.dmp 导入的文件名,结合上面的 directory=dmpdata 就将’/data/u01/dmpdata/filename.dmp’;导入目标服务器(需要注意大小写);
  4. remap_tablespace=um_dev:um----->um_dev:导出表空间 ,um:导入表空间;
  5. remap_schema=u_um_dev:u_um ----> u_um_dev:导出用户 u_um:导入用户。
  • 命令示例:
impdp kf_gs_workflow_0604/a@gfmisdev directory='DUMP_DIR' DUMPFILE='GSU_WORKFLOW_20240604.dmp' LOGFILE='GSU_WORKFLOW_20240604.log' REMAP_SCHEMA=GSU_WORKFLOW:kf_gs_workflow_0604 REMAP_TABLESPACE=GRP:USERS

3.exp/expdp对比及示例

在这里插入图片描述

a. exp

可通过 exp help=y 命令查询相关参数

  • imp常用参数说明,可以根据需要指定不同的参数来控制导入的方式和内容。
参数使用说明
TABLES指定要导出的表格。例如,TABLES=table1,table2。
FILE指定导出文件的路径和名称。例如,FILE=/path/to/export.dmp。
LOG指定导出过程的日志文件路径和名称。例如,LOG=/path/to/export.log。
QUERY指定要导出数据的查询条件。例如,QUERY=“ SELECT * FROM TABLE WHERE column_name=‘value’”。
ROWS控制是否导入表中的行数据。可以是Y或N。
STATISTICS指定是否导出统计信息。可以是ALL、ESTIMATE或NONE。
GRANTS指定是否导出对象的授权信息。可以是Y、N或FULL。
CONSISTENT指定是否导出一致性视图。可以是Y或N。
INDEXES指定是否导出索引。可以是Y或N。
COMPRESS指定是否压缩导出文件。可以是Y或N。
  • 命令格式:
exp username/password@[database] FILE=[导出文件路径] TABLES=[要导出的表名]
  • 命令示例:
--完全导出:
exp user/password@SID file=E:/test/dmp/kf_workflow_0512.dmp full=y

--导出A、B表
exp user/password@SID file= E:/test/dmp/kf_workflow_0512.dmp tables=(A,B)

b.expdp

可通过 expdp help=y 命令查询相关参数

  • imp常用参数说明,可以根据需要指定不同的参数来控制导入的方式和内容。
参数使用说明
SCHEMAS指定要导出的模式名。例如,SCHEMAS=schema1,schema2。
INCLUDE指定要包括的对象类型。例如,INCLUDE=TABLE,VIEW将只导出表和视图。
EXCLUDE指定要排除的对象类型。例如,EXCLUDE=INDEX将排除索引的导出。
DIRECTORY指定导出文件的目录对象。例如,DIRECTORY=datapump_dir。
DUMPFILE指定导出文件的名称。例如,DUMPFILE=export.dmp。
LOGFILE指定导出操作的日志文件名称。例如,LOGFILE=export.log。
PARALLEL指定并行导出的进程数。
DIRECTORY指定导出文件的目录对象。例如,DIRECTORY=datapump_dir。
COMPRESSION指定导出文件是否压缩。可以是ALL、DATA_ONLY、METADATA_ONLY或NONE。
CONTENT指定导出内容。可以是ALL、DATA_ONLY、METADATA_ONLY或METADATA_ONLY_EXCLUDING_DATA。
QUERY指定导出的数据查询条件。例如,QUERY=“WHERE column_name=‘value’”。
FILESIZE指定导出文件的最大文件大小。
JOB_NAME指定导出作业的名称。
VERSION给定系统版本号的对象。例如,VERSION=SCN,SCN为版本号。
  • 命令格式:
expdp 用户名/密码@数据库实例 DIRECTORY=目录名称 DUMPFILE=导出文件名.dmp   EXCLUDE=TABLE:"IN ('table1','table2')"  INCLUDE=TABLE:"IN ('EMPLOYEES', 'DEPARTMENTS')"   FULL=Y
  • 命令示例:
--按用户导
expdp user/password@SID schemas=u_mom_um dumpfile=expdp.dmp directory=dmp logfile=expdlog.log;

--按表名导
expdp user/password@SID tables=test1,test2 dumpfile=expdp.dmp directory=dmp logfile=expdlog.log;

--按查询条件导
expdp user/password@SID directory=dmp dumpfile=expdp.dmp Tables=test query='WHERE id<20' logfile=expdlog.log;

--按表空间导
expdp user/password@SID directory=dmp dumpfile=expdp.dmp TABLESPACES={#表空间1},{#表空间2} logfile=expdlog.log;

--导整个库
expdp user/password@SID directory=dmp dumpfile=expdp.dmp FULL=y logfile=expdlog.log;
  • 具体命令示例:
--按照表空间导
expdp user/password@SID directory=DMPDATA dumpfile=tbs2022.dmp TABLESPACES=tbs  logfile=expdlog.log;

--用EXCLUDE、INCLUDE时,对应的符号需要进行转译
expdp GSU_ELEMENT/yth2023 schemas=GSU_ELEMENT dumpfile=GSU_ELEMENT_20240604.dmp EXCLUDE=TABLE:\"IN\(\'GFM_TB_RESULT\',\'GAP_PAYEE_ACCOUNT\'\)\" directory=GSZX logfile=GSU_ELEMENT_20240604.log

3.其他事项

  1. 在执行导入导出时需要进入oracle去执行。
--linux 
su oracle ;--到这就可执行导入导出
sqlplus / as sysdba;

--windows: 
win + r,cmd,enter; --到这可执行导入导出
sqlplus 用户名/口令@数据库名 as sysdba;
  1. 在执行导入、导出的命令时,可通过nohup来执行,nohup是一个在Unix和类Unix操作系统上用来忽略HUP(挂起)信号并运行命令的实用程序。通过使用nohup,您可以使命令在后台运行,即使当前Shell终端窗口关闭,也能继续运行。
  2. 使用exp 导出文件需要使用imp导入,数据泵类型需要一致。
  3. EXCLUDE、INCLUDE时,对应的符号需要进行转译;

三、执行导入导出前置条件

如果数据库用户已经存在,并有相关目录跳过此步骤。

1.创建角色并授权

--创建角色
create user orcl identified by orclorcl;

--授权
grant dba ,connect ,resource ,select any table,create view to orcl;

--查看用户创建情况
select * from all_users;

2.创建目录映射

 CREATE DIRECTORY my_dir AS '/path/to/directory';
  1. 查询现有目录是否满足条件
select * from DBA_DIRECTORIES;
  1. 创建文件夹
--linux
mkdir /data/u01/dmpdata

--windows下自行创建文件,记下目录
  1. 文件夹创建后给oracle用户授权
chown -R oracle /data/u01/dmpdata
  1. 数据库里执行SQL创建导入/导出目录(目录映射)
--目录对象在数据库中注册,并映射到实际物理目录的路径。
create or replace directory DMPDATA as '/data/u01/dmpdata';
  1. 为建立的目录赋权限,须要以其余用户运行,建议在sys用户下执行
grant read,write on directory DMPDATA to {#用户名};

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1807008.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

基于关键词自动采集抖音视频排名及互动数据(点赞、评论、收藏)

在当今的社交媒体时代&#xff0c;抖音作为一个热门短视频平台&#xff0c;吸引了大量用户和内容创作者。对于研究和分析抖音上的热门视频及其互动数据&#xff08;如点赞、评论、收藏等&#xff09;&#xff0c;自动化的数据采集工具显得尤为重要。本项目旨在开发一个基于关键…

Linux基础I/O

一&#xff0c;系统文件I/O 写文件: #include <stdio.h> #include <sys/types.h> #include <sys/stat.h> #include <fcntl.h> #include <unistd.h> #include <string.h> int main() {umask(0);int fd open("myfile", O_WRO…

【Java】解决Java报错:StackOverflowError

文章目录 引言1. 错误详解2. 常见的出错场景2.1 无限递归2.2 递归深度过大2.3 方法调用层次过深 3. 解决方案3.1 优化递归算法3.2 尾递归优化3.3 增加调用栈大小3.4 检查递归终止条件 4. 预防措施4.1 使用迭代替代递归4.2 尾递归优化4.3 合理设计递归算法4.4 调整JVM参数4.5 定…

【Qt】Qt QTreeWidget隐藏列名称(横向表头)

1. 效果 未隐藏 隐藏 2. 方法 方法1 ui->treeWidget->header()->hide();方法2 ui->treeWidget->header()->setVisible(false);

RDK X3(aarch64) 测试手柄

0. 环境 - 亚博智能的ROSMASTER-X3 标准版 - XDK X3 1.0 - 冰原狼等win10免驱的手柄 1. RDK X3 1.0 串口通信 波特率 921600 root/root mobaterm -> Session -> VNC -> 192.168.8.108:5900 -> runrise 2. 测试 ROSMASTER-X3 标准版 配套的手柄 安装 …

【Java SE】字符串常量池详解,什么情况下字符串String对象存在常量池,通过==进行判断,字符串创建及截取后是否同一个对象

复习字符串创建方式 字符串的31种构造方法 public String();创建一个空白字符串&#xff0c; 不含有任何内容public String(char[] array);根据字符数组的内容&#xff0c;来创建对应的字符串public String(byte[] array);根据字节数组的内筒&#xff0c;来创建对应的字符串 …

物联网设计竞赛_8_Jetson Orin Nano安装pytorch与torchvision

我的新板子到了&#xff0c;型号是jetson orin Nano与之前的jetson nano稍有不同我发现库又得从新下载 我的pip3的版本是3.8.10&#xff0c;jetpack版本5.1.1&#xff0c;又得重新开始下载库&#x1f62d; 安装pytorch: 得科学上网&#xff1a; PyTorch for Jetson - Jetson …

U-Net: Convolutional Networks for Biomedical Image Segmentation--论文笔记

U-Net: Convolutional Networks for Biomedical Image Segmentation 资料 1.代码地址 2.论文地址 https://arxiv.org/pdf/1505.04597 3.数据集地址 论文摘要的翻译 人们普遍认为&#xff0c;深度网络的成功训练需要数千个带注释的训练样本。在本文中&#xff0c;我们提出…

nodejs最新某东h5st(4.7.2)参数分析与javascript逆向纯算法还原(含算法源码)(2024-06-09)

一、作者声明&#xff1a; 文章仅供学习交流与参考&#xff01;严禁用于任何商业与非法用途&#xff01;否则由此产生的一切后果均与作者无关&#xff01;如有侵权&#xff0c;请联系作者本人进行删除&#xff01; 二 、写在前面 h5st从4.1一路更新到4.7.2&#xff0c;逐渐vmp…

57.Semaphore信号量

用来限制能同时访问共享资源的线程上限。只是适合限制单机线程数量。 Slf4j public class SemaphoreDemo {public static void main(String[] args) {Semaphore semaphore new Semaphore(3);for (int i 0; i < 10; i) {new Thread(() -> {try {semaphore.acquire();//…

Spring配置多数据库(采用数据连接池管理)

一&#xff0c;前言 大家在开发过程中&#xff0c;如果项目大一点就会遇到一种情况&#xff0c;同一个项目中可能会用到很多个数据源&#xff0c;那么这篇文章&#xff0c;博主为大家分享在spring应用中如何采用数据库连接池的方式配置配置多数据源。 本篇文章采用大家用的最…

【PLG洞察】| 飞书成功之路:关键在分销裂变

引言 随着企业服务市场的发展&#xff0c;Product-Led Growth&#xff08;PLG&#xff0c;产品驱动增长&#xff09;模式逐渐成为众多SaaS企业的首选战略。在这个背景下&#xff0c;字节跳动旗下的企业协作与管理平台——飞书&#xff0c;凭借其独特的分销裂变策略&#xff0c…

【教程】让小爱音箱Play增强版接入Mi-GPT

转载请注明出处&#xff1a;小锋学长生活大爆炸[xfxuezhagn.cn] 如果本文帮助到了你&#xff0c;欢迎[点赞、收藏、关注]哦~ 项目地址&#xff1a;https://github.com/idootop/mi-gpt MiIOT&#xff1a;小米小爱音箱Play 增强版 - 产品规格 - Xiaomi Miot Spec 实现效果图&…

ABC 357 G Stair-like Grid

link 其实是我之前写的一篇博客的推广 大意&#xff1a; 一个阶梯型&#xff0c;第 i i i行有 ⌈ i / 2 ⌉ ∗ 2 \left \lceil i/2 \right \rceil*2 ⌈i/2⌉∗2个方块&#xff0c;总共有n行。在其中给定 m m m个点无法经过&#xff0c;求从左上角到右下角的方案数。其中每次移…

macOS优化工具CleanMyMac2024免费版电脑性能提升 存储空间释放 电脑维护 高效易用 延长电脑使用寿命

【CleanMyMac】是一款专为macOS系统设计的优化和清理软件&#xff0c;它的核心特性就是帮助我们提升电脑性能&#xff0c;释放存储空间。&#x1f680; CleanMyMac绿色免费版下载如下&#xff1a;记得保存哈&#xff0c;以防失效&#xff1a; https://pan.quark.cn/s/9b08114…

【电机控制】FOC算法验证步骤

【电机控制】FOC算法验证步骤 文章目录 前言一、PWM——不接电机1、PWMA-H-50%2、PWMB-H-25%3、PWMC-H-0%4、PWMA-L-50%5、PWMB-L-75%6、PWMC-L-100% 二、ADC——不接电机1.电流零点稳定性、ADC读取的OFFSET2.电流钳准备3.运放电路分析1.电路OFFSET2.AOP3.采样电路的采样值范围…

Spring03-依赖注入(DI)

依赖注入 概念 依赖注入&#xff08;Dependency Injection,DI&#xff09;。 依赖 : 指Bean对象的创建依赖于容器 . Bean对象的依赖资源 . 注入 : 指Bean对象所依赖的资源 , 由容器来设置和装配 . 构造器注入 前面已经介绍过&#xff0c;参考4、IOC创建对象的方式 Set方…

2024最新华为OD机试-C/D卷 - 在线OJ使用说明

文章目录 &#x1fa90;在线 OJ 入口&#x1f3a7;申请OD使用权限&#x1f353;在线 OJ 的使用说明OJ主界面专题系列语言支持评测结果 &#x1fa90;在线 OJ 入口 &#x1f517; 2024最新华为OD机试 - 在线OJ入 &#x1f3a7;申请OD使用权限 本专栏配套 OJ 的为了配合考友更高…

Vue数据动态代理机制的实现

Object.defineProperty() &#xff08;1&#xff09;这个方法是ES5新增的 &#xff08;2&#xff09;这个方法的作用是&#xff1a;给对象新增属性&#xff0c;或者设置对象原有的属性 &#xff08;3&#xff09;用法&#xff1a;Object.defineProperty(给哪个对象新增属性,‘…

【简单介绍下DALL-E2,什么是DALL-E2?】

&#x1f308;个人主页: 程序员不想敲代码啊 &#x1f3c6;CSDN优质创作者&#xff0c;CSDN实力新星&#xff0c;CSDN博客专家 &#x1f44d;点赞⭐评论⭐收藏 &#x1f91d;希望本文对您有所裨益&#xff0c;如有不足之处&#xff0c;欢迎在评论区提出指正&#xff0c;让我们共…