原标题:Linux系统上Oracle数据库备份和还原操作说明
Oracle数据库备份和还原操作说明
使用Oralce数据库导出(expdp)、数据库导入(impdp)程序在Oracle数据库之间传输数据对象,进行数据库的备份和还原。数据泵程序需要在数据库服务端使用。使用导出备份时可能产生数据不一致,所以需要先停止应用程序,再进行导出备份。
以下假设数据库帐户为imanage,对同名的schema进行备份和还原。
因为Linux系统中有文件权限控制,请用oracle用户登录操作系统,再进行以下操作。
1. 创建备份目录
1. 在数据库服务器上手工创建文件夹,比如:/home/oracle/data_dp,用于存放备份文件。比如,启动一个终端会话,执行以下命令。
2. 启动一个终端会话,使用sqlplus以system帐户登入数据库,并执行如下语句创建和查看目录EXPDP_DIR。如图1所示。
说明:EXPDP_DIR对应数据库服务器上已存在的路径,请根据实际环境修改。
3. 如果想用8thManage数据库帐户来备份,需要授予读写目录EXPDP_DIR的权限,执行如下语句。如图1所示。
图1
2. 备份
启动一个终端会话,先设置NLS_LANG参数,再运行expdp,使用system帐户导出imanage schema。执行以下命令,如图2所示。
参数说明:
ORCL:数据库网络服务名(使用Oracle Net Manager配置)
directory:导出文件保存目录
schemas:要导出的方案的列表
dumpfile:导出备件文件名
logfile:导出的日志文件名
图2
3. 还原
此处假设还原的目标数据库的schema为new_imanage(数据库用户),数据库表空间为new_imanage。
1. 在sqlplus中,使用system帐户连接数据库查看是否存在同名的数据库表空间。查看语句如下:
如果已存在同名的数据库表空间,则跳到第2步操作;
如果不存在相同的数据库表空间,需先创建,执行语句如下:
注意:datafile的路径是数据库服务器操作系统中的路径,请根据实际环境修改。
2. 在sqlplus中,使用system帐户连接数据库查看是否存在同名的schemas。查看语句如下:
如果已存在相同的schemas,需先删除再创建。
删除schemas语句如下:
创建schemas语句如下:
3. 启动一个终端会话,先设置NLS_LANG参数,再运行impdp,使用system帐户导入imanage schema。执行以下命令:
参数说明:
ORCL:数据库网络服务名(使用Oracle Net Manager配置)
directory:备份文件保存目录(比如值为EXPDP_DIR)
dumpfile:使用的备件文件名
logfile:导入的日志文件名
remap_schema:将一个方案中的对象加载到另一个方案
remap_tablespace:将表空间对象重新映射到另一个表空间
备注:
还原时impdp.log文件中出现以下ORA-编号开头的信息是正常的,可以忽略。
ORA-31684: 对象类型 USER:"XXX" 已存在
ORA-39082: 对象类型 XXX 已创建, 但带有编译警告
ORA-39126: 在 KUPW$WORKER.PUT_DDLS [TABLE_STATISTICS] 中 Worker 发生意外致命错误 (这是最后导入统计信息出错,可以忽略)