expdp 和 impdp 数据泵方式


### 1

1.以Linux的Oracle用户登录主机,然后创建导出文件的存放目录/data/oracle/dump(可自定义)
mkdir  -p  /data/oracle/dump

2.以Oracle数据库的sys用户登录(登录命令为 sqlplus / as sysdba )后执行如下命令

create directory shj as '/data/oracle/dump';                             #创建导出文件的存放目录
#create or replace directory dpdata1 as '/home/oracle/dump';        #用于修改已创建的目录(请根据实际情况选择性执行)

select * from dba_directories where directory_name='shj';     #查看导出文件的存储位置
grant read,write on directory shj to songhongjun;                                #对用户进行授权


3.退出Oracle的sys用户,以linux的oracle用户登录,并执行如下命令
    SQL> select current_scn from v$database;   

    CURRENT_SCN
    -----------
        1139842

    SQL> exit
    
    [oracle@bogon ogg]$ expdp songhongjun/bagayalu  DIRECTORY=SHJ  schemas=songhongjun   dumpfile=shj.dmp flashback_scn=1139842;
    

### 2
1.源端shj.dmp  远程拷贝到 目标端 dump/ 目录下
scp shj.dmp 192.168.214.139:/data/oracle/dump/

### 3
跟源端一样的步骤 登录 sysdba
1.
SQL>  create directory shj as '/data/oracle/dump';

Directory created.

SQL>  grant read,write on directory shj to songhongjun;

Grant succeeded.

SQL>  select * from dba_directories where directory_name='SHJ';

OWNER
------------------------------------------------------------
DIRECTORY_NAME
------------------------------------------------------------
DIRECTORY_PATH
--------------------------------------------------------------------------------
SYS
SHJ
/data/oracle/dump


2.

[oracle@bogon dump]$ impdp songhongjun/bagayalu directory=shj dumpfile=shj.dmp remap_tablespace=SHJ2:SHJ

有两个方法

(1)transform=segment_attributes:n
     这个参数是导入到用户的默认表空间下

(2)第二个方法是remap_tablespace这个参数,可以替换表空间名
     remap_tablespace=SHJ2:SHJ

posted @ 2021-01-22 16:52  RedArmy  阅读(74)  评论(0编辑  收藏  举报