oracle database about impdp&empdp -----数据泵导入导出 11g/12c

导出前必要条件

创建存放备份的目录:directory

mkdir <Folder_path>
chmod 775 <Folder_path>
chown oracle:oinstall <Folder_path>

授予用户对目录的读写权限:

create or replace directory <directory_name> as ’ <Folder_path> ';
select * from dba_directories;
grant read,write on directory <directory_name> to <user_name>;

查询oracle server端的字符集:

select * from nls_database_parameters; select * from nls_database_parameters;

 SQL>select userenv('language') from dual;

      USERENV('LANGUAGE')
      ----------------------------------------
      AMERICAN_AMERICA.AL32UTF8

设置字符集:
设置中文字符集:
export NLS_LANG=“SIMPLIFIED CHINESE_CHINA”.AL32UTF8

                      export NLS_LANG=AMERICAN_AMERICA.AL32UTF8

                      export NLS_LANG=AMERICAN_AMERICA.ZHS16GBK

expdp导出示例:

(1)导出表
expdp <user_name>/<password> DIRECTORY=<directory_name> DUMPFILE=<table_name>.dmp TABLES=<table_name> logfile=<table_name>.log

(2)导出用户 (schema,与用户对应)
expdp “sys/<password> as sysdba” DIRECTORY=<directory_name> DUMPFILE=<user_name>.dmp SCHEMAS=<user_name> logfile=<user_name>.log

(3)导出表空间
expdp “sys/<password> as sysdba” DIRECTORY=<directory_name> DUMPFILE=<tablespace>.dmp TABLESPACES=<tablespace_name>,<tablespace_name> logfile=<tablespace>.log

(4)导出数据库
expdp “sys/<password> as sysdba” DIRECTORY=<directory_name> DUMPFILE=<instance>.dmp FULL=Y logfile=<instance>.log;

impdp导入示例:

(1)导入表
impdp <user_name>/<password> DIRECTORY=<directory_name> DUMPFILE=<table_name> .dmp TABLES=<table_name> logfile=<table_name>.log

(2)导入用户
impdp “sys/<password> as sysdba” DIRECTORY=<directory_name> DUMPFILE=<user_name>.dmp SCHEMAS=<user_name> logfile=<user_name>.log;

(3)导入表空间
impdp “sys/<password> as sysdba” DIRECTORY=<directory_name> DUMPFILE=<tablespace>.dmp TABLESPACES=<tablespace_name> logfile=<tablespace>.log;

(4)导入数据库
impdp “sys/<password> as sysdba” DIRECTORY=<directory_name> DUMPFILE=<instance>.dmp FULL=Y logfile=<instance>.log;

注意 在目标库中新建对应表空间否则可能报错

关于参数
PARALLEL 1/2/3 并行度
CLUSTER Y/N N为只在当前节点执行不跨节点

11g例:

导出baiyyy用户的数据

nohup expdp ‘sys/sysadmin as sysdba’ DIRECTORY=bakz DUMPFILE=20230529xxx.dmp logfile=expdp20230529xxx.log schemas=baiyyy > nohup_expdp.out &

导入baiyyy用户的数据

nohup impdp zyz/123456@192.168.2.10:1521/orcl directory=bakz dumpfile=20230529xxx.dmp logfile=impdp20230529xxx.log schemas=baiyyy > nohup_impdp.out &

导出全库数据

nohup expdp zyz/123456 directory=bakz dumpfile=expdp2023.dmp logfile=expdp2023.log full=yes parallel=2 > nohup_expdp.out &

导入全库数据
nohup impdp ‘sys/sysadmin as sysdba’ directory=bakz dumpfile=expdp2023.DMP logfile=impdp2023.log full=yes parallel=2 > nohup_impdp.out &

查看现有directory
select DIRECTORY_NAME,DIRECTORY_PATH from dba_directories;
创建directory
create or replace directory bakz as ‘/oracledata’;

12c 例

Oracle 12c引入了可插拔数据库(PDB)的概念,作为其多租户架构的一部分。导出时需注意使用的用户与连接的数据库。

不同pdb之间用户与directory 是互相隔离的。

可通过sqlplus 下 使用 show pdbs; 命令查看所有pdb。

如果使用sys用户直接连接、 导出的是cdb的内容

nohup expdp \'sys/123456 as sysdba\' directory=bakz dumpfile=expdpcdb.dmp logfile=expdpcdb.log full=yes  > nohup_impcdb.out &

此时导出cdb库中的内容。

使用sys 用户导出pdb中的内容

nohup expdp \'sys/123456@pdb as sysdba\' directory=bakz dumpfile=expdppdb.dmp logfile=expdppdb.log full=yes  > nohup_imppdb.out &

此时使用@连接方式连接pdb,需注意tnsnames.ora 文件维护是否正确

tnsnames.ora 文件位置 为 $ORACLE_HOME/network/admin

使用其他用户导出pdb中的内容

需在pdb中创建用户授予权限

nohup expdp pdbuser/123456@pdb  directory=bakz dumpfile=expdppdb.dmp logfile=expdppdb.log full=yes  > nohup_imppdb.out &
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

为什么不问问神奇的海螺呢丶

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值