用Linux命令备份oracle表,Linux系统上Oracle数据库备份和还原操作说明

原标题: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

7fbf17415c631a332ca16c42b0428ba8.png

2. 备份

启动一个终端会话,先设置NLS_LANG参数,再运行expdp,使用system帐户导出imanage schema。执行以下命令,如图2所示。

参数说明:

ORCL:数据库网络服务名(使用Oracle Net Manager配置)

directory:导出文件保存目录

schemas:要导出的方案的列表

dumpfile:导出备件文件名

logfile:导出的日志文件名

图2

30222b9f7069cc5bb6ca7c91c2e56999.png

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 发生意外致命错误 (这是最后导入统计信息出错,可以忽略)返回搜狐,查看更多

责任编辑:

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值