首页 数据库 mysql教程 oracle 数据泵导入导出

oracle 数据泵导入导出

Jun 07, 2016 pm 02:50 PM
data oracle 导入 导出 数据

--21.1 Data Pump工具 Data Pump 从oracledatabase 10g开始引入了data pump(数据泵)工具,它提供了一种基于服务器的数据导出导入使用程序。 所有的data pump都作为一个服务器进程,数据不再必须由一个客户程序处理。Data Pump工具的导出和导入实现 Oracle数据

--21.1 Data Pump工具
 Data Pump
     从oracledatabase 10g开始引入了data pump(数据泵)工具,它提供了一种基于服务器的数据导出导入使用程序。
 所有的data pump都作为一个服务器进程,数据不再必须由一个客户程序处理。Data Pump工具的导出和导入实现
 Oracle数据库之间数据的传输。
     Data Pump工具中包含Data Pump Export和Data Pump Import,所使用的命令行客户程序为expdp和impdp。
    
 【注意】
      在10g之前,传统的导出导入分别使用exp工具和imp工具。从oracle database 10g开始,不仅保留了原有的
  exp和imp工具,还提供了数据泵导出导入工具expdp和impdp。
      从11g开始,在传统的export和import应用程序中可用的任何特性在data pump中都可用。
      在使用expdp和impdp工具时,应该注意以下几点:
      1  exp和imp是客户端工具程序,它们既可以在客户端使用,也可以在服务器端使用。
      2  expdp和impdp是服务器工具程序,它们只能在oracle服务器端使用,不能再客户端使用。
      3  imp只适用于exp导出的文件,不适用于expdp导出文件;impdp只适用与expdp导出的文
         件,不适用于exp导出文件。data pump导出导入所得到的文件跟传统的import/export
         应用程序导出导入的文件不兼容。  
  
  【pump特点】
      与原有的export和import使用程序相比,oracle的data pump工具的功能特点如下:
      1 在导出或者导入作业中,能够控制用于此作业的并行线程的数量。
      2 支持在网络上进行导出导入,而不需要是使用转储文件集。
      3 如果作业失败或者停止,能够重新启动一个data pump作业。并且能够挂起恢复导出导入作业。
      4 通过一个客户端程序能够连接或者脱离一个运行的作业。
      5 空间估算能力,而不需要实际执行导出。
      6 可以指定导出导入对象的数据库版本。允许对导出导入对象进行版本控制,以便与低版本数据库兼容。
  
  【pump数据字典】
      数据字典                说明
      dba_datapump_jobs       显示运行数据泵作业的信息,也可以使用user_datapump_jobs变量
      dba_datapump_sessions   提供数据泵作业会话级别的信息
      datapump_paths          提供一系列有效的对象类型,可以将其与export或者impdp的include或者exclude参数关联起来
      dba_directories         提供一系列已定义的目录
 
--21.2 使用datapump工具的准备工作
   1 在环境变量中队bin目录进行配置。默认情况下,安装oracle数据库时,将自动配置相应的环境变量,
     例如D:/oracle/product/10.2.0/db_1/BIN
   2 在oracle安装路径的bin文件夹中,确定expdp.exe和impdp.exe文件的存在。
   3 创建一个外部目录。
     data pump要求为将要创建和读取的数据文件和日志文件创建目录,用来指向
     使用的外部目录。在oracle中创建目录对象时,可以使用 create directory
     语句。
   【实例】
     1,检查,高级环境变量-pathpath里面有无bin目录
     2,检查expdp.exe、impdp.exe文件是否存在。
     3,建立目录
        c:/> sqlplus /nolog
        sql> conn sys/sys as sysdba
        sql> create directory mypump as 'd:/app/temp';
        sql> grant read, write on directory mypump to scott;
        sql> select * from dba_directories; 查询所有目录
  
--21.3 数据泵导出选项
   参数             说明
   help             显示用于导出的联机帮助,默认为n
   compress         指定要压缩的数据,可选值有:all、data_only、metadata_only和none
   content          筛选导出的内容,可选值有:all、data_only和metadata_only
   directory        指定用于日志文件和转储文件集的目的目录
   dumpfile         为转储文件指定名称和目录
   encryption       输出的加密级别,可选值有:all、data_only、encrypted_columns_only、etadata_only和none
   exclude          排除导出的对象和数据
   flashback_sch    用于数据库在导出过程中闪回的系统更改号
   flashback_time   用于数据库在导出过程中闪回的时间戳
   include          规定用于导出对象和数据的标准
   logfile          导出日志的名字和可选的目录名字
   parfile          指定参数文件名
   query            在导出过程中从表中筛选行
   reuse_dmupfiles  覆盖已有的转储文件
   status           显示data pump作业的详细状态
   attach           将一个客户会话连接到一个当前运行的data pumpexport作业上
   transportable    只为表模式导出而导出元数据
   full             在一个full模式下通知data pump导出所有的数据和元数据
   schemas          在一个schemas模式导出中命名将导出的模式
   tables           列出将用于一个table模式导出而导出的表和分区
   tablespaces      列出将导出的表空间
   transport_tablespaces 
                    指定一个transportable tablespace模式导出
   transport_full_check
                    是否应该验证正在导出的表空间是一个自包含集
  expdp交互模式中的命令列表
  参数              说明
  add_file          向转储文件集中添加转储文件
  exit_client       退出客户机会话并使作业处于运行状态
  kill_job          分离和删除作业
  paraliel           改变用户data pump export作业的工作进程的数量
  start_job         启动、恢复当前作业
  status            显示data pump export的作业状态
  reuse_dmpfiles    是否覆盖现有的转储文件。设置为y时,现有的转储文件将被覆盖;
                    当使用默认值n时,如果转储文件已经存在就会产生一个错误。
  stop_job          依次关闭执行的作业并退出客户机。stop_job=immediate将立即关闭数据泵作业
  【实例】
    1,进入目录 D:/>cd D:/oracle/product/10.2.0/db_1/BIN
    2,expdp help=y 列出所有参数
    3,交互模式下
       /BIN> expdp system/system
       等待一会,按下ctrl c 进入export模式
       Export>stop_job 停止作业
        /BIN>
--21.4 实现数据导出
导出模式
模式              参数              说明                                       操作角色      
full              full              导出整个数据库                             exp_full_database
schema            schemas           导出一个或者多个用户模式中的数据和元数据   拥有exp_full_database角色,可以导出任何模式,
                                                                               否则只能导出自己的模式
table             tables            导出一组特定的表                           拥有exp_full_database角色,可以导出任何模式的表
tablespace        tablespaces       导出一个或者多个表空间的数据               exp_full_database
transportable     transport_tablespaces
   tablespace                       导出表空间中对象的元数据                   exp_full_database
   【实例】
    1,进入bin目录
    2,表模式导出
       expdp scott/scott_2009 directory=mypump dumpfile=expdptab.dmp tables=dept,emp
       (select * from dba_tablespaces; alter tablespace testspace online;)
    3,全库模式导出
       expdp system/system directory=mypump dumpfile=expdp.dmp full=y
    4,schema模式导出
       expdp system/system directory=mypump dumpfile=expdp.dmp schemas=scott nologfile=y
    5,表空间数据导出
       expdp system/system directory=mypump dumpfile=expdpspace.dmp tablespaces=users
    6,可移动表空间导出
       1 将user表空间设置成只读状态,然后执行可移动表空间元数据导出
       sql>  alter tablespace users read only;
       BIN>  expdp system/system directory=mypump dumpfile=exptrans.dmp transport_tablespaces=users;
       sql>  alter tablespace users online;
        
--21.5 使用导出参数
  1 使用exclude参数
        在expdp命令中可以指定参数exclude,用来实现从data pump export中排除对象,如果排除了一个对象,也将排除
    所有与它相关的对象。
        使用exclude的格式如下:
        exclude=object_type[:name_clause][,...]
        其中,object_type可以是任何oracle对象类型,包括权限、索引和表等;name_clause用来限制返回的值。
  2 使用exclude参数  
        如果在data pump export中使用include,可以只导出符合要求的对象,其他所有对象均被排除。使用include
    参数的格式如下:
        include=object_type[:name_clause][,...]
  3 使用query参数
        对于满足exclude和include标准的对象,将会导出该对象的所有行。这时,可以使用query参数来限制返回的行,
     使用query参数格式如下:
        query=[schema.][table_name:]query_clause
        其中,schema是指定表所属的用户名,或者所属的用户模式名称;
     table_name指定表名;query_clause用来指定限制条件。
   【实例】
    1 exclude参数,注意表名要大写。
      expdp system/system directory=mypump dumpfile=expdpexclude.dmp tablespaces=users exclude=table:"in('EMP')" exclude=table:"in('DEPT')"
    2 include参数,注意表名要大写。导出users表空间的索引信息
      expdp system/system directory=mypump dumpfile=expdpinclude.dmp tablespaces=users include=index
    3 query参数
      expdp system/system directory=mypump dumpfile=expdpquery.dmp tables=scott.dept query=/"where deptno=10/"
     
     
--21.6 数据泵导入选项
关键字               说明 (默认)
------------------------------------------------------------------------------
ATTACH                连接到现有作业, 例如 ATTACH [=作业名]。
CONTENT               指定要加载的数据, 其中有效关键字为:
                      (ALL), DATA_ONLY 和 METADATA_ONLY。
DIRECTORY             供转储文件, 日志文件和 sql 文件使用的目录对象。
DUMPFILE              要从 (expdat.dmp) 中导入的转储文件的列表,
                      例如 DUMPFILE=scott1.dmp, scott2.dmp, dmpdir:scott3.dmp。
ENCRYPTION_PASSWORD   用于访问加密列数据的口令关键字。
                      此参数对网络导入作业无效。
ESTIMATE              计算作业估计值, 其中有效关键字为:
                      (BLOCKS) 和 STATISTICS。
EXCLUDE               排除特定的对象类型, 例如 EXCLUDE=TABLE:EMP。
FLASHBACK_SCN         用于将会话快照设置回以前状态的 SCN。
FLASHBACK_TIME        用于获取最接近指定时间的 SCN 的时间。
FULL                  从源导入全部对象 (Y)。
HELP                  显示帮助消息 (N)。
INCLUDE               包括特定的对象类型, 例如 INCLUDE=TABLE_DATA。
JOB_NAME              要创建的导入作业的名称。
LOGFILE               日志文件名 (import.log)。
NETWORK_LINK          链接到源系统的远程数据库的名称。
NOLOGFILE             不写入日志文件。
PARALLEL              更改当前作业的活动 worker 的数目。
PARFILE               指定参数文件。
QUERY                 用于导入表的子集的谓词子句。
REMAP_DATAFILE        在所有 DDL 语句中重新定义数据文件引用。
REMAP_SCHEMA          将一个方案中的对象加载到另一个方案。
REMAP_TABLESPACE      将表空间对象重新映射到另一个表空间。
REUSE_DATAFILES       如果表空间已存在, 则将其初始化 (N)。
SCHEMAS               要导入的方案的列表。
SKIP_UNUSABLE_INDEXES 跳过设置为无用索引状态的索引。
SQLFILE               将所有的 SQL DDL 写入指定的文件。
STATUS                在默认值 (0) 将显示可用时的新状态的情况下,
                      要监视的频率 (以秒计) 作业状态。
STREAMS_CONFIGURATION 启用流元数据的加载
TABLE_EXISTS_ACTION   导入对象已存在时执行的操作。
                      有效关键字: (SKIP), APPEND, REPLACE 和 TRUNCATE。
TABLES                标识要导入的表的列表。
TABLESPACES           标识要导入的表空间的列表。
TRANSFORM             要应用于适用对象的元数据转换。
                      有效的转换关键字: SEGMENT_ATTRIBUTES, STORAGE
                      OID 和 PCTSPACE。
TRANSPORT_DATAFILES   按可传输模式导入的数据文件的列表。
TRANSPORT_FULL_CHECK  验证所有表的存储段 (N)。
TRANSPORT_TABLESPACES 要从中加载元数据的表空间的列表。
                      仅在 NETWORK_LINK 模式导入操作中有效。
VERSION               要导出的对象的版本, 其中有效关键字为:
                      (COMPATIBLE), LATEST 或任何有效的数据库版本。
                      仅对 NETWORK_LINK 和 SQLFILE 有效。
下列命令在交互模式下有效。
注: 允许使用缩写
命令               说明 (默认)
------------------------------------------------------------------------------
CONTINUE_CLIENT       返回到记录模式。如果处于空闲状态, 将重新启动作业。
EXIT_CLIENT           退出客户机会话并使作业处于运行状态。
HELP                  总结交互命令。
KILL_JOB              分离和删除作业。
PARALLEL              更改当前作业的活动 worker 的数目。
                      PARALLEL=
START_JOB             启动/恢复当前作业。
                      START_JOB=SKIP_CURRENT 在开始作业之前将跳过
                      作业停止时执行的任意操作。
STATUS                在默认值 (0) 将显示可用时的新状态的情况下,
                      要监视的频率 (以秒计) 作业状态。
                      STATUS[=interval]
STOP_JOB              顺序关闭执行的作业并退出客户机。
                      STOP_JOB=IMMEDIATE 将立即关闭
                      数据泵作业。
  【实例】
    查看命令:impdp help=y
    1,表模式导入
        impdp scott/scott_2009 directory=mypump dumpfile=expdptab.dmp tables=dept,emp table_exists_action=replace
    2,全库模式导入
       impdp system/system directory=mypump dumpfile=expdp.dmp full=y
    3,schema模式导入
       impdp system/system directory=mypump dumpfile=expdp.dmp schemas=scott nologfile=y
    4,表空间数据导入
       impdp system/system directory=mypump dumpfile=expdpspace.dmp tablespaces=users
    5,可移动表空间导入
       1 将user表空间设置成只读状态,然后执行可移动表空间元数据导出
       sql>  alter tablespace users read only;
       BIN>  impdp system/system directory=mypump dumpfile=exptrans.dmp transport_tablespaces=users;
       sql>  alter tablespace users online;
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
2 周前 By 尊渡假赌尊渡假赌尊渡假赌
仓库:如何复兴队友
1 个月前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒险:如何获得巨型种子
1 个月前 By 尊渡假赌尊渡假赌尊渡假赌

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

oracle数据库日志会保存多久 oracle数据库日志会保存多久 May 10, 2024 am 03:27 AM

Oracle 数据库日志的保留期限取决于日志类型和配置,包括:重做日志:由 "LOG_ARCHIVE_DEST" 参数配置的最大大小决定。归档重做日志:由 "DB_RECOVERY_FILE_DEST_SIZE" 参数配置的最大大小决定。在线重做日志:不归档,在数据库重启时丢失,保留期限与实例运行时间一致。审计日志:由 "AUDIT_TRAIL" 参数配置,默认保留 30 天。

oracle数据库启动步骤顺序为 oracle数据库启动步骤顺序为 May 10, 2024 am 01:48 AM

Oracle 数据库启动顺序为:1. 检查前置条件;2. 启动监听器;3. 启动数据库实例;4. 等待数据库打开;5. 连接到数据库;6. 验证数据库状态;7. 启用服务(如果需要);8. 测试连接。

oracle需要多少内存 oracle需要多少内存 May 10, 2024 am 04:12 AM

Oracle 所需内存量取决于数据库大小、活动水平和所需性能水平:用于存储数据缓冲区、索引缓冲区、执行 SQL 语句和管理数据字典缓存。具体数量受数据库大小、活动水平和所需性能水平影响。最佳实践包括设置适当的 SGA 大小、调整 SGA 组件大小、使用 AMM 和监控内存使用情况。

oracle中某个字符出现的次数怎么看出来 oracle中某个字符出现的次数怎么看出来 May 09, 2024 pm 09:33 PM

要在 Oracle 中查找字符出现的次数,执行以下步骤:获取字符串的总长度;获取字符所在子字符串的长度;计算字符出现的次数:用总长度减去子字符串长度。

oracle数据库服务器硬件配置要求 oracle数据库服务器硬件配置要求 May 10, 2024 am 04:00 AM

Oracle 数据库服务器硬件配置要求:处理器:多核,主频至少 2.5 GHz,大型数据库建议 32 核以上。内存:小型数据库至少 8GB,中等规模 16-64GB,大型数据库或高负载工作负载高达 512GB 或更多。存储:SSD 或 NVMe 磁盘,RAID 阵列提高冗余和性能。网络:高速网络(10GbE 或更高),专用网卡,低延迟网络。其他:稳定电源、冗余组件、兼容操作系统和软件、散热和冷却系统。

70B模型秒出1000token,代码重写超越GPT-4o,来自OpenAI投资的代码神器Cursor团队 70B模型秒出1000token,代码重写超越GPT-4o,来自OpenAI投资的代码神器Cursor团队 Jun 13, 2024 pm 03:47 PM

70B模型,秒出1000token,换算成字符接近4000!研究人员将Llama3进行了微调并引入加速算法,和原生版本相比,速度足足快出了快了13倍!不仅是快,在代码重写任务上的表现甚至超越了GPT-4o。这项成果,来自爆火的AI编程神器Cursor背后团队anysphere,OpenAI也参与过投资。要知道在以快着称的推理加速框架Groq上,70BLlama3的推理速度也不过每秒300多token。 Cursor这样的速度,可以说是实现了近乎即时的完整代码文件编辑。有人直呼好家伙,如果把Curs

AI初创集体跳槽OpenAI,Ilya出走后安全团队重整旗鼓! AI初创集体跳槽OpenAI,Ilya出走后安全团队重整旗鼓! Jun 08, 2024 pm 01:00 PM

上周,在内部的离职潮和外部的口诛笔伐之下,OpenAI可谓是内忧外患:-侵权寡姐引发全球热议-员工签署「霸王条款」被接连曝出-网友细数奥特曼「七宗罪」辟谣:根据Vox获取的泄露信息和文件,OpenAI的高级领导层,包括Altman在内,非常了解这些股权回收条款,并且签署了它们。除此之外,还有一个严峻而紧迫的问题摆在OpenAI面前——AI安全。最近,五名与安全相关的员工离职,其中包括两名最著名的员工,“超级对齐”团队的解散让OpenAI的安全问题再次被置于聚光灯下。《财富》杂志报道称,OpenA

oracle定时任务每天都执行一次创建步骤 oracle定时任务每天都执行一次创建步骤 May 10, 2024 am 03:03 AM

要在 Oracle 中创建每天执行一次的定时任务,需要执行以下三个步骤:创建一个作业。为作业添加一个子作业,并设置其计划表达式为“INTERVAL 1 DAY”。启用作业。

See all articles