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