江湖开发者 | Java粉
网站地图
首页> 数据库> oracle数据泵还原(impdp命令)
2017
04-18

oracle数据泵还原(impdp命令)

oracle数据泵还原(impdp命令)

1、全库模式导入[full]
   impdp orcldev/oracle directory=backup_path dumpfile=orcldev_schema.dmp full=Y table_exists_action=replace 

   table_exists_action有三种选项:

   (1)truncate (2) replace (3) append
   一般来说,在还原数据库操作的时候,首先要删除这个用户,然后在进行impdp还原操作。
   eg:
   (1)SQL>DROP USER orcldev CASCADE;
   (2)impdp orcldev/oracle directory=backup_path dumpfile=orcldev_2013.dmp full=Y 

2、Schema模式导入[schema]
   --还原orcldev这个方案(用户)
   impdp orcldev/oracle directory=backup_path dumpfile=orcldev_schema.dmp schemas=orcldev table_exists_action=replace

3、表模式导入[table]
   --还原某个用户下的具体的表
   (1)windows版本:
   impdp orcldev/oracle directory=backup_path dumpfile=orcldev_table.dmp tables='TAB_TEST' table_exists_action=replace
   (2)unix版本:需要将'单引号进行转义操作
   impdp orcldev/oracle directory=backup_path dumpfile=orcldev_table.dmp tables=\'TAB_TEST\' table_exists_action=replace

4、表空间模式导入[tablespace]
   impdp orcldev/oracle directory=backup_path dumpfile=orcldev_tablespace.dmp tablespace=user,orcldev

5、传输表空间模式导入[Transportable Tablespace]
   (1)Oracle_Online
   You cannot export transportable tablespaces and then import them into a database at a lower release level. The target database must be at the same or higher release level as the source database.
   The TRANSPORT_TABLESPACES is valid only when the NETWORK_LINK parameter is also specified.
   意思就说,目标库的版本要等于或者高于源数据库的版本,TRANSPORT_TABLESPACES参数选项有效前提条件是NETWORK_LINK参数需被指定。
   查询数据库版本号SQL语句:SELECT * FROM v$version;

   impdp orcldev/oracle DIRECTORY=dackup_path NETWORK_LINK=db_link_test01 TRANSPORT_TABLESPACES=test0001 TRANSPORT_FULL_CHECK=n TRANSPORT_DATAFILES='app/oradata/test0001.dbf'

   (2)创建数据库dbLink方法:
   语法:
      CREATE [PUBLIC] DATABASE LINK LINK_NAME 
      CONNECT TO Username IDENTIFIED BY Password
      USING 'ConnectString';

   注释:
   1)创建dblink需有CREATE DATABASE LINK或CREATE PUBLIC DATABASE LINK的系统权限以及用来登录到远程数据库用户必须有CREATE SESSION权限。
   2)ConnectString指的是在tnsnames.ora文件中配置的监听名称。
   3)当GLOBAL_NAME=TRUE时,dblink名必须与远程数据库的全局数据库名GLOBAL_NAME相同;否则,可以任意命名。

   (3)查看GLOBAL_NAME参数方法:
       SQL> show parameters global_name;
          NAME                                    TYPE        VALUE
         ----------------------------------- ----------- ------------------------------
         global_names                         boolean     FALSE

6、REMAP_SCHEMA参数
   众所周知:IMP工具的FROMUSER和TOUSER参数可以实现将一个用户的的数据迁移到另外一个用户。
   impdp数据泵使用REMAP_SCHEMA参数来实现不同用户之间的数据迁移;
   语法:
           REMAP_SCHEMA=source_schema:target_schema
           impdp orcldev/oracle DIRECTORY=backup_path DUMPFILE=oracldev.dmp REMAP_SCHEMA=orcldev:orcltwo
   与REMAP_SCHEMA类似的参数选项,如REMAP_TABLESPACE将源表空间的所有对象导入目标表空间。

7、REMAP_TABLE参数
   将源表数据映射到不同的目标表中
   impdp orcldev/oracle DIRECTORY=backup_path dumpfile=oracldev.dmp remap_table=TAB_TEST:TEST_TB
   数据导入到TEST_TB表中,但是该表的索引等信息并没有相应的创建,需要手工初始化。
8、REMAP_DATAFILE参数

   语法:REMAP_DATAFILE=source_datafile:target_datafile
   Oracle_Online:
   Remapping datafiles is useful when you move databases between platforms that have different file naming conventions. The source_datafile and target_datafile names should be exactly as you want them to appear in the SQL statements where they are referenced. Oracle recommends that you enclose datafile names in quotation marks to eliminate ambiguity on platforms for which a colon is a valid file specification character.

9、PARALLEL参数
   使用PARALLEL参数可以提高数据泵还原的效率,前提是必须有多个expdp的文件,如expdp01.dmp,expdp02.dmp,expdp03dmp等等,不然会有问题。运行impdp命令时,会先启动一个WORKER进程将METADATA导入,然后再启动多个WORKER进程将数据以及其他对象导入,所以在前期只会看到一个WORKER在导入METADATA,而且IMPDP也需要DUMP文件是多个,也可以使用%U来进行导入。建议使用PARALLEL参数时,使用%U选项,否则执行效果不理想。
   impdp orcldev/oracle directory=backup_path dumpfile=orcldev_schema_%U.dmp schemas=orcldev parallel=4

   备注:而在11GR2后EXPDP和IMDP的WORKER进程会在多个INSTANCE启动,所以DIRECTORY必须在共享磁盘上,如果没有设置共享磁盘还是指定cluster=no来防止报错。
10、CONTENT参数
   CONTENT参数选项有ALL,DATA_ONLY和METADATA_ONLY,默认情况是ALL。可以选择只导入元数据或者是只导入数据。
   例如: 
  

   impdp orcldev/oracle directory=backup_path dumpfile=orcldev_schema.dmp schemas=orcldev CONTENT=DATA_ONLY

11、其他选项

   include、exclude、parfile、query和version参数选项与EXPDP命令的参数选项一致。



Java江湖     
全部评论:

表情验证码,看不清楚,换一张

随机文章

云标签

公众号

微信

分享:分享我们的知识;专注:专注个人技术的提升;