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 @   RedArmy  阅读(76)  评论(0编辑  收藏  举报
编辑推荐:
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
· 一个奇形怪状的面试题:Bean中的CHM要不要加volatile?
· [.NET]调用本地 Deepseek 模型
· 一个费力不讨好的项目,让我损失了近一半的绩效!
阅读排行:
· 百万级群聊的设计实践
· 永远不要相信用户的输入:从 SQL 注入攻防看输入验证的重要性
· 全网最简单!3分钟用满血DeepSeek R1开发一款AI智能客服,零代码轻松接入微信、公众号、小程
· .NET 10 首个预览版发布,跨平台开发与性能全面提升
· 《HelloGitHub》第 107 期
点击右上角即可分享
微信分享提示