Oracle数据泵实现全库导入导
数据库导出
创建导出文件的目录directory
登陆数据库。
创建directory,名称为DUMP_DIR
,用于在导出时指定导出到的目录:
create directory DUMP_DIR as 'D:\OracleExpdp';
注意,(路径)要用单引号,双引号会报错。
查看directory:
select * from dba_directories; --查看directory
数据泵将数据库全部导出
如下,为 expdp
导出数据库全部数据的命令。
记得修改正确的username/password
,数据库服务名SID
,dumpfile
为导出的数据文件名,默认名为expdat.dmp
,逗号分割可以指定导出到多个文件,logfile
为导出的日志文件名,若不指定,默认生成名为export.log
的日志文件。
expdp username/password@SID directory=DUMP_DIR dumpfile=文件名.dmp logfile=文件名.log full=y
FULL
表示导出整个数据库,默认N。
注:用户需要授权导出的权限,若是系统认证,或system/sys高级用户,则不需要。
授予用户导入导出操作相关的权限:
grant read,write on directory DUMP_DIR to username; grant exp_full_database to username;
数据库导入
创建文件的目录directory
登陆数据库。同样创建directory,指定导入时文件所在的路径:
create directory DUMP_DIR as 'D:\OracleExpdp';
DUMP_DIR 指向 dmp 导出的数据文件所在路径。
导入全部数据
impdp username/password@SID directory=DUMP_DIR dumpfile=文件名.dmp logfile=文件名.log full=y
同样,用户要有足够的权限
使用系统认证(或系统用户)进行数据库导出和导入
使用系统认证(sysdba角色)登陆数据库,免除用户权限的问题,可以更方便的直接执行导出或导入。
创建目录
DUMP_DIR
create directory DUMP_DIR as 'D:\OracleExpdp';
全部导出
expdp '/@SID as sysdba' directory=DUMP_DIR dumpfile=文件名.dmp logfile=文件名.log full=y
如果报错,则使用
"'/@SID as sysdba'"
【实际使用没问题】形式,或\'/@SID as sysdba\'
或 sys
用户
expdp 'sys/admin@SID as sysdba' directory=DUMP_DIR dumpfile=文件名.dmp logfile=文件名.log full=y
"'sys/admin@SID as sysdba'"
全部导入
impdp '/@SID as sysdba' directory=DUMP_DIR dumpfile=文件名.dmp logfile=文件名.log full=y
"'/@SID as sysdba'"
或sys用户
impdp 'sys/admin@SID as sysdba' directory=DUMP_DIR dumpfile=文件名.dmp logfile=文件名.log full=y
"'sys/admin@SID as sysdba'"
expdp报错UDE-00014: invalid value for parameter, ‘attach’
这个原因在于@SID
位置放置不正确。密码password
和@SID
之前不能有空格,并且要紧挨着。也就是上面所示的写法。系统认证的/
也要写成/@SID
。
参考UDE-00014: invalid value for parameter, ‘attach’终极解决方案之一
保证源和目标数据库的字符集一致
select userenv('language') from dual;
查看数据库的字符集。
通常字符集在创建数据库时指定好,创建后则不应该修改。
如果导入导出时不一致,推荐的做法是,删除目标数据库,重新创建与源库字符集一样的数据库,而不是直接进行字符集的修改。
具体参见:修改oracle数据库字符集编码
expdp/impdp相比exp/imp的优点
imp 需要先建立表空间、用户等再导入。impdp则不需要。
expdp/impdp 支持全库导入导出;效率相对更高。
表空间块大小与配置大小不一致导致导入时无法创建表空间的问题
impdp导入是会创建表空间、用户等,但是,如果表空间大小与配置的不一样就会报错ORA-29339
ORA-29339: 表空间块大小 16384 与配置的块大小不匹配
通常在直接用plsql
创建表空间时,也有可能出现这个错误。这是由于创建表空间时指定的块大小与系统设置的块大小不一致。
解决办法通常是修改db_Nk_cache_size
的大小。但是,有些块大小是和系统存储的块大小一致的,不允许修改。
如下为自己测试,有些能够修改,并且提示“已更改”,但是查看仍然没有变化。
SQL> alter system set db_4k_cache_size=8m;
系统已更改。
SQL> show parameter 4k;
NAME TYPE VALUE
------------------------------------ ---------------------- ------------------------------
db_4k_cache_size big integer 32M
最终也是没有解决。
【其原因应该是源库没有使用默认的块大小(block_size)】
最开始的表空间导入失败,导致后面剩余的数据或信息的导入都失败。
正确的处理,应该是创建表空间,然后在依次执行用户、表、数据的导入,而不能直接进行整库的导入。
具体通过各个部分进行导出导入,参见参考文章。
附:expdp help=y
查看expdp的帮助信息
附:关于grants=Y
参数
在ORA-39083 - During Impdp中看到有使用grants=Y
参数。其具体作用和使用暂时不清楚。
exp username/password tables=(mytables, moretables) file=mytable.dmp lpg=mytable.log grants=Y
imp username/password tables=(mytables, moretables) file=mytable.dmp log=myimport.log grants=Y
附:全库(整体数据库)备份迁移推荐使用rman
全库或整体数据库的迁移,通常还是推荐使用 rman
工具。
附:exp
、imp
的示例
exp "'/@SID as sysdba'" file=D:\dumpfile.dmp full=y
imp "'/@SID as sysdba'" file=D:\dumpfile.dmp full=y
imp "'/@SID as sysdba'" file=D:\dumpfile.dmp full=y ignore=y
exp "'/ as sysdba'"@SID file=D:\dumpfile.dmp full=y
imp "'/ as sysdba'"@SID file=D:\dumpfile.dmp full=y
## imp "'/ as sysdba'"@SID file=D:\dumpfile.dmp full=y ignore=y