expdp的用法

article/2025/10/23 6:46:24
exp/imp与expdp/impdp的用法区别
1:把用户usera的对象导到用户userb,用法区别在于fromuser=usera touser=userb ,remap_schema='usera':'usera' 。例如

imp system/passwd fromuser=usera touser=userb file=/oracle/exp.dmp log=/oracle/exp.log;
impdp system/passwd directory=expdp dumpfile=expdp.dmp remap_schema='usera':'userb' logfile=/oracle/exp.log;

2:更换表空间,用exp/imp的时候,要想更改表所在的表空间,需要手工去处理一下,
如alter table xxx move tablespace_new之类的操作。
用impdp只要用remap_tablespace='tabspace_old':'tablespace_new'

3:当指定一些表的时候,使用exp/imp 时,tables的用法是 tables=('table1','table2','table3')。
expdp/impdp的用法是tables='table1','table2','table3'

4:
是否要导出数据行
exp (ROWS=Y 导出数据行,ROWS=N 不导出数据行)
expdp content(ALL:对象+导出数据行,DATA_ONLY:只导出对象,METADATA_ONLY:只导出数据的记录)
语法如下:
EXPDP和IMPDP使用说明EXPDP和IMPDP使用说明         Oracle Database 10g引入了最新的数据泵(Data Dump)技术,使DBA或开发人员可以将数据库元数据(对象定义)和数据快速移动到另一个oracle数据库中.
        数据泵导出导入(EXPDP和IMPDP)的作用
        1,实现逻辑备份和逻辑恢复.
        2,在数据库用户之间移动对象.
        3,在数据库之间移动对象
        4,实现表空间搬移.
        数据泵导出导入与传统导出导入的区别
        在10g之前,传统的导出和导入分别使用EXP工具和IMP工具,从10g开始,不仅保留了原有的EXP和IMP工具,还提供了数据泵导出导入工具EXPDP和IMPDP.使用EXPDP和IMPDP时应该注意的事项;
        EXP和IMP是客户段工具程序,它们既可以在可以客户端使用,也可以在服务端使用.
        EXPDP和IMPDP是服务端的工具程序,他们只能在ORACLE服务端使用,不能在客户端使用
        IMP只适用于EXP导出文件,不适用于EXPDP导出文件;IMPDP只适用于EXPDP导出文件,而不适用于EXP导出文件.
        数据泵导出包括导出表,导出方案,导出表空间,导出数据库4种方式.
        EXPDP命令行选项
        1. ATTACH
        该选项用于在客户会话与已存在导出作用之间建立关联.语法如下
        ATTACH=[schema_name.]job_name
        Schema_name用于指定方案名,job_name用于指定导出作业名.注意,如果使用ATTACH选项,在命令行除了连接字符串和ATTACH选项外,不能指定任何其他选项,示例如下:
        Expdp scott/tiger ATTACH=scott.export_job
        2. CONTENT
        该选项用于指定要导出的内容.默认值为ALL
        CONTENT={ALL | DATA_ONLY | METADATA_ONLY}
        当设置CONTENT为ALL 时,将导出对象定义及其所有数据.为DATA_ONLY时,只导出对象数据,为METADATA_ONLY时,只导出对象定义
        Expdp scott/tiger DIRECTORY=dump DUMPFILE=a.dump
        CONTENT=METADATA_ONLY
        3. DIRECTORY
        指定转储文件和日志文件所在的目录
        DIRECTORY=directory_object
        Directory_object用于指定目录对象名称.需要注意,目录对象是使用CREATE DIRECTORY语句建立的对象,而不是OS 目录
        Expdp scott/tiger DIRECTORY=dump DUMPFILE=a.dump
        建立目录:
        CREATE DIRECTORY dump as ‘d:dump’;
        查询创建了那些子目录:
        SELECT * FROM dba_directories;
        4. DUMPFILE
        用于指定转储文件的名称,默认名称为expdat.dmp
        DUMPFILE=[directory_object:]file_name [,….]
        Directory_object用于指定目录对象名,file_name用于指定转储文件名.需要注意,如果不指定directory_object,导出工具会自动使用DIRECTORY选项指定的目录对象
        Expdp scott/tiger DIRECTORY=dump1 DUMPFILE=dump2:a.dmp
        5. ESTIMATE
        指定估算被导出表所占用磁盘空间分方法.默认值是BLOCKS
        EXTIMATE={BLOCKS | STATISTICS}
        设置为BLOCKS时,oracle会按照目标对象所占用的数据块个数乘以数据块尺寸估算对象占用的空间,设置为STATISTICS时,根据最近统计值估算对象占用空间
        Expdp scott/tiger TABLES=emp ESTIMATE=STATISTICS
        DIRECTORY=dump DUMPFILE=a.dump
        6. EXTIMATE_ONLY
        指定是否只估算导出作业所占用的磁盘空间,默认值为N
        EXTIMATE_ONLY={Y | N}
        设置为Y时,导出作用只估算对象所占用的磁盘空间,而不会执行导出作业,为N时,不仅估算对象所占用的磁盘空间,还会执行导出操作.
        Expdp scott/tiger ESTIMATE_ONLY=y NOLOGFILE=y
        7. EXCLUDE
        该选项用于指定执行操作时释放要排除对象类型或相关对象
        EXCLUDE=object_type[:name_clause] [,….]
        Object_type用于指定要排除的对象类型,name_clause用于指定要排除的具体对象.EXCLUDE和INCLUDE不能同时使用
        Expdp scott/tiger DIRECTORY=dump DUMPFILE=a.dup EXCLUDE=VIEW
        8. FILESIZE
        指定导出文件的最大尺寸,默认为0,(表示文件尺寸没有限制)
        9. FLASHBACK_SCN
        指定导出特定SCN时刻的表数据
        FLASHBACK_SCN=scn_value
        Scn_value用于标识SCN值.FLASHBACK_SCN和FLASHBACK_TIME不能同时使用
        Expdp scott/tiger DIRECTORY=dump DUMPFILE=a.dmp
        FLASHBACK_SCN=358523
        10. FLASHBACK_TIME
        指定导出特定时间点的表数据
        FLASHBACK_TIME=”TO_TIMESTAMP(time_value)”
        Expdp scott/tiger DIRECTORY=dump DUMPFILE=a.dmp FLASHBACK_TIME=
        “TO_TIMESTAMP(’25-08-2004 14:35:00’,’DD-MM-YYYY HH24:MI:SS’)”
        11. FULL
        指定数据库模式导出,默认为N
        FULL={Y | N}
        为Y时,标识执行数据库导出.
        12. HELP
        指定是否显示EXPDP命令行选项的帮助信息,默认为N
        当设置为Y时,会显示导出选项的帮助信息.
        Expdp help=y
        13. INCLUDE
        指定导出时要包含的对象类型及相关对象
        INCLUDE = object_type[:name_clause] [,… ]
        14. JOB_NAME
        指定要导出作用的名称,默认为SYS_XXX
        JOB_NAME=jobname_string15. LOGFILE
        指定导出日志文件文件的名称,默认名称为export.log
        LOGFILE=[directory_object:]file_name
        Directory_object用于指定目录对象名称,file_name用于指定导出日志文件名.如果不指定directory_object.导出作用会自动使用DIRECTORY的相应选项值.
        Expdp scott/tiger DIRECTORY=dump DUMPFILE=a.dmp logfile=a.log
        16. NETWORK_LINK
        指定数据库链名,如果要将远程数据库对象导出到本地例程的转储文件中,必须设置该选项.
        17. NOLOGFILE
        该选项用于指定禁止生成导出日志文件,默认值为N.
        18. PARALLEL
        指定执行导出操作的并行进程个数,默认值为1
        19. PARFILE
        指定导出参数文件的名称
        PARFILE=[directory_path] file_name
        20. QUERY
        用于指定过滤导出数据的where条件
        QUERY=[schema.] [table_name:] query_clause
        Schema用于指定方案名,table_name用于指定表名,query_clause用于指定条件限制子句.QUERY选项不能与CONNECT=METADATA_ONLY,EXTIMATE_ONLY,TRANSPORT_TABLESPACES等选项同时使用.
        Expdp scott/tiger directory=dump dumpfiel=a.dmp
        Tables=emp query=’WHERE deptno=20’
        21. SCHEMAS
        该方案用于指定执行方案模式导出,默认为当前用户方案.
        22. STATUS
        指定显示导出作用进程的详细状态,默认值为0
        23. TABLES
        指定表模式导出
        TABLES=[schema_name.]table_name[:partition_name][,…]
        Schema_name用于指定方案名,table_name用于指定导出的表名,partition_name用于指定要导出的分区名.
        24. TABLESPACES
        指定要导出表空间列表
        25. TRANSPORT_FULL_CHECK
        该选项用于指定被搬移表空间和未搬移表空间关联关系的检查方式,默认为N.
        当设置为Y时,导出作用会检查表空间直接的完整关联关系,如果表空间所在表空间或其索引所在的表空间只有一个表空间被搬移,将显示错误信息.当设置为N时,导出作用只检查单端依赖,如果搬移索引所在表空间,但未搬移表所在表空间,将显示出错信息,如果搬移表所在表空间,未搬移索引所在表空间,则不会显示错误信息.
        26. TRANSPORT_TABLESPACES
        指定执行表空间模式导出27. VERSION
        指定被导出对象的数据库版本,默认值为COMPATIBLE.
        VERSION={COMPATIBLE | LATEST | version_string}
        为COMPATIBLE时,会根据初始化参数COMPATIBLE生成对象元数据;为LATEST时,会根据数据库的实际版本生成对象元数据.version_string用于指定数据库版本字符串.
        调用EXPDP
        使用EXPDP工具时,其转储文件只能被存放在DIRECTORY对象对应的OS目录中,而不能直接指定转储文件所在的OS目录.因此,使用EXPDP工具时,必须首先建立DIRECTORY对象.并且需要为数据库用户授予使用DIRECTORY对象权限.
        CREATE DIRECTORY dump dir AS ‘DUMP’;
        GRANT READ, WIRTE ON DIRECTORY dump_dir TO scott;
        1,导出表
        Expdp scott/tiger DIRECTORY=dump_dir DUMPFILE=tab.dmp TABLES=dept,emp
        2,导出方案
        Expdp scott/tiger DIRECTORY=dump_dir DUMPFILE=schema.dmp
        SCHEMAS=system,scott
        3.导出表空间
        Expdp system/manager DIRECTORY=dump_dir DUMPFILE=tablespace.dmp
        TABLESPACES=user01,user02
        4,导出数据库
        Expdp system/manager DIRECTORY=dump_dir DUMPFILE=full.dmp FULL=Y
        使用IMPDP
        IMPDP命令行选项与EXPDP有很多相同的,不同的有:
        1,REMAP_DATAFILE
        该选项用于将源数据文件名转变为目标数据文件名,在不同平台之间搬移表空间时可能需要该选项.
        REMAP_DATAFIEL=source_datafie:target_datafile
        2,REMAP_SCHEMA
        该选项用于将源方案的所有对象装载到目标方案中.
        REMAP_SCHEMA=source_schema:target_schema
        3,REMAP_TABLESPACE
        将源表空间的所有对象导入到目标表空间中
        REMAP_TABLESPACE=source_tablespace:target:tablespace
        4.REUSE_DATAFILES
        该选项指定建立表空间时是否覆盖已存在的数据文件.默认为N
        REUSE_DATAFIELS={Y | N}
        5.SKIP_UNUSABLE_INDEXES
        指定导入是是否跳过不可使用的索引,默认为N
        6,SQLFILE
        指定将导入要指定的索引DDL操作写入到SQL脚本中
        SQLFILE=[directory_object:]file_name
        Impdp scott/tiger DIRECTORY=dump DUMPFILE=tab.dmp SQLFILE=a.sql
        7.STREAMS_CONFIGURATION
        指定是否导入流元数据(Stream Matadata),默认值为Y.
        8,TABLE_EXISTS_ACTION
        该选项用于指定当表已经存在时导入作业要执行的操作,默认为SKIP
        TABBLE_EXISTS_ACTION={SKIP | APPEND | TRUNCATE | FRPLACE }
        当设置该选项为SKIP时,导入作业会跳过已存在表处理下一个对象;当设置为APPEND时,会追加数据,为TRUNCATE时,导入作业会截断表,然后为其追加新数据;当设置为REPLACE时,导入作业会删除已存在表,重建表病追加数据,注意,TRUNCATE选项不适用与簇表和NETWORK_LINK选项
        9.TRANSFORM
        该选项用于指定是否修改建立对象的DDL语句
        TRANSFORM=transform_name:value[ bject_type]
        Transform_name用于指定转换名,其中SEGMENT_ATTRIBUTES用于标识段属性(物理属性, 存储属性,表空间,日志等信息),STORAGE用于标识段 存储属性,VALUE用于指定是否包含段属性或段存储属性,object_type用于指定对象类型.
        Impdp scott/tiger directory=dump dumpfile=tab.dmp
        Transform=segment_attributes:n:table
        10.TRANSPORT_DATAFILES
        该选项用于指定搬移空间时要被导入到目标数据库的数据文件
        TRANSPORT_DATAFILE=datafile_name
        Datafile_name用于指定被复制到目标数据库的数据文件
        Impdp system/manager DIRECTORY=dump DUMPFILE=tts.dmp
        TRANSPORT_DATAFILES=’/user01/data/tbs1.f’
        调用IMPDP
        1, 导入表
        Impdp scott/tiger DIRECTORY=dump_dir DUMPFILE=tab.dmp
        TABLES=dept,emp
        Impdp system/manage DIRECTORY=dump_dir DUMPFILE=tab.dmp
        TABLES=scott.dept,scott.emp REMAP_SCHEMA=SCOTT:SYSTEM
        第一种方法表示将DEPT和EMP表导入到SCOTT方案中,第二种方法表示将DEPT和EMP表导入的SYSTEM方案中.
        注意,如果要将表导入到其他方案中,必须指定REMAP SCHEMA选项.
        2,导入方案
        Impdp scott/tiger DIRECTORY=dump_dir DUMPFILE=schema.dmp
        SCHEMAS=scott
        Impdp system/manager DIRECTORY=dump_dir DUMPFILE=schema.dmp
        SCHEMAS=scott REMAP_SCHEMA=scott:system
        3,导入表空间
        Impdp system/manager DIRECTORY=dump_dir DUMPFILE=tablespace.dmp
        TABLESPACES=user01
        4,导入数据库
        Impdp system/manager DIRECTORY=dump_dir DUMPFILE=full.dmp FULL=y

http://chatgpt.dhexx.cn/article/sPyRBsSE.shtml

相关文章

expdp/impdp 详细参数解释

数据泵导出实用程序提供了一种用于在 Oracle 数据库之间传输 数据对象的机制。该实用程序可以使用以下命令进行调用: 示例: expdp scott/tiger DIRECTORYdmpdir DUMPFILEscott.dmp 您可以控制导出的运行方式。具体方法是: 在 expdp 命令后输入 各种参数。要指定各参数, 请使用关…

Oracle详解:exp/imp和expdp/impdp的区别

Oracle详解:exp/imp和expdp/impdp的区别 结论: 在10g之前,传统的导出和导入分别使用EXP工具和IMP工具,从10g开始,不仅保留了原有的EXP和IMP工具,还提供了数据泵导出导入工具EXPDP和IMPDP。 1、exp和expdp最明显的区…

使用expdp(非本地)远程导出数据

背景: 前段时间,需要从异地一个测试数据库中将测试数据(一张表)导入本地库,表数据量大约500万,字段160多个,开始用了exp/imp方式,速度奇慢,不能忍,于是转而使用expdp/impdp方式。 e…

运维 —— expdp、impdp

一、exp/imp与expdp/impdp 1)exp和imp是客户端工具程序,它们既可以在可以客户端使用,也可以在服务端使用。 2)expdp和impdp是服务端的工具程序,他们只能在ORACLE服务端使用, 不能在客户端使用。 3)字符集的问题到expdp/impdp数据泵已经消除…

expdp / impdp 用法详解

一、注意事项: EXP和IMP是客户端工具程序,它们既可以在客户端使用,也可以在服务端使用。 EXPDP和IMPDP是服务端的工具程序,他们只能在ORACLE服务端使用,不能在客户端使用。 IMP只适用于EXP导出的文件,不适…

expdp/impdp 数据泵导入导出

业务场景: 在工作中,涉及到oracle数据库迁移,使用navicat等其他工具 容易报错,一系列问题很麻烦,今天记录一下操作流程及个人理解(文章参考了很多文档和博客); EXPDP数据导出 请自…

rest_framework--过滤器filters--搜索

rest_framework–过滤器filters–搜索 view from rest_framework.pagination import PageNumberPagination from rest_framework import mixins from rest_framework import viewsets from rest_framework import filtersfrom .models import Goods from .serializers import G…

gateway整合filters

Unable to find GatewayFilterFactory with name AddRequestParamter 首先确定你要做的是用nacos整合gateway,然后使用gateway配置filters对请求进行修改。 一、首先在gateway微服务的application.yml或者bootstrap.yml文件进行filter的配置 // A code block ser…

php apply filters,WordPress学习——apply_filters()详解

前两天学习了 add_filters() 函数,详见>>> WordPress学习——add_filter()详解 ,今天趁热打铁再来学习下它的使用。一般情况下 add_filters() 有两种方式触发,一种是当程序运行到特定时候 WordPress 程序会判断用户是否对某些参数做了新的定义,如果有则优先使用用…

filters过滤器

这是通过过滤器写的一个只显示10个字的效果图。 1):什么时候用到过滤器? 绑定一些复杂数据类型的时候用到过滤器 2):以下两种方式定义过滤器: 第一种:Vue.filter()定义全局过滤器&#xff0…

vue filters的使用

filters 过滤器:「Vue.js 允许你自定义过滤器,可被用于一些常见的文本格式化。过滤器可以用在两个地方:双花括号插值和 v-bind 表达式 (后者从 2.1.0 开始支持)。过滤器应该被添加在 JavaScript 表达式的尾部,由“管道”符号指示&…

【前端】Vue---过滤器filters详解

一、认识过滤器: 格式化数据的一个工具 过滤器的作用:用于文本格式化,仅仅作为格式化操作,不做复杂的业务处理过滤器的使用方式:通过管道符号(|)来使用过滤器的使用位置:mustache插值和v-bing的表达式 二、过滤器的使用 //如何使用使用过滤器?我们用一个叫做管道…

Fiddler工具 — Fiddler过滤器(Filters)详解

1、Filters介绍 Filters:过滤器,帮助我们过滤请求。 如果需要过滤掉与测试项目无关的抓包请求,更加精准的展现抓到的请求,而不是杂乱的一堆,那功能强大的 Filters 过滤器能帮到你。 总结:Filters过滤器的…

Vue项目中过滤器(filters)的用法

过滤器使用场景 在调取接口的返回数据的时候,我们经常能够得到各种Number类型的数据。 这种格式的数据,很多时候都是表明对应的类型。 如果直接返回到页面上展示,对于操作人员来讲,没有任何意义。 所以,一般的情况…

vue初学篇----过滤器(filters)

过滤器使用&#xff0c;直接上代码 <template><div class"filters"><h1 v-text"filtersTitle"></h1><input v-model"filtersText"/><div>{{filtersText | filtersTextChange}}</div></div> <…

mysql删掉数据库失败_如何删除MySQL数据库?

mysql删掉数据库失败 MySQL is a very popular opensource database it is used by a lot of different types and size companies. In this post, we will look at how to drop or delete MySQL databases? MySQL是一种非常流行的开源数据库,许多类型和规模的公司都在使用它…

数据库如何删除数据

1、drop (删除表)&#xff1a;删除内容和定义&#xff0c;释放空间。简单来说就是把整个表去掉.以后要新增数据是不可能的,除非新增一个表。 drop语句将删除表的结构被依赖的约束&#xff08;constrain),触发器&#xff08;trigger)索引&#xff08;index);依赖于该表的存储过程…

Mongo删除数据库/集合

Mongo 删除数据库/集合 1.使用mongo 连接数据库 2.show dbs 查看所有的数据库 3.删除mongo数据库 1.先切换到mongo数据库 use mongo 2.执行 db.dropDatabase()命令 结果:{ "dropped" : "mongo", "ok" : 1 } 3.执行show dbs 发现mongo库已被删…

mysql 如何删除数据库中所有的表

方法1&#xff1a; SELECT concat(DROP TABLE IF EXISTS , table_name, ;) FROM information_schema.tables WHERE table_schema mydb;mydb换成你想删除的数据库的名字 这样可以生成一个批量处理的sql语句&#xff0c;你需要再运行一次这个结果集 就可以删除所有的表而不删除…

Oracle数据库----删除数据库

一、使用DBCA删除数据库 1、单击“开始”→“Oracle_OraDB12Home1”→“Database Configuration Assistant”&#xff0c;进入删除步骤的第一步&#xff0c;选择“删除数据库”。 2、单击“下一步”按钮&#xff0c;如图所示。在数据库列表中选择需要删除的数据&#xff0c;例…