Linux系统下,Oracle数据库的备份与还原

数据备份:


1.使用Linux系统下的数据库管理员账号连接linux终端。


2. 执行以下语句,创建“bak_dir”文件夹。

 mkdir bak_dir


3. 执行以下语句,为“bak_dir”文件夹赋予读、写和执行权限。

 chmod 777 bak_dir


4. 执行以下语句,以sysdba用户登录Oracle数据库服务器。

 sqlplus 数据库管理员账号/密码@数据库实例名 as sysdba


5. 执行以下语句,将“bak_dir”指定为“/opt/oracle/bak_dir”。
 create or replace directory bak_dir as '/opt/oracle/bak_dir'

 commit


6. 执行以下语句,将“bak_dir”的读、写和执行权限赋给xx(数据用户名)用户。
 grant all on directory bak_dir to xx


 commit
7. 执行以下语句,退出oracle数据库服务器。
 quit


执行以下语句,将sysdb用户的表备份到“bak_dir”目录下。
8.expdp xx(要导出表所在的数据库用户名)/xx(密码)@数据库实例名 directory=bak_dir dumpfile=expdb_xx.dmp logfile=expdb_xxlog tables=表名


 


数据还原:


1.在命令行输入:sqlplus "/as sysdba"


2. 执行以下语句登录xx数据库,用户名:xx,密码:xx(请输入当地实际密码)
 conn xx/xx;


3.如果恢复的表中有涉及到触发器的请停止触发器,例:A表


alter table A disable all triggers; 


commit;


4. 执行以下语句退出当前用户

 quit;


5. 执行以下语句,恢复用户数据。
 impdp xx/xx@数据库实例名 directory=bak_dir table_exists_action=truncate dumpfile=expdb_xx.dmp logfile=impdb_xx.log


5.在命令行输入:sqlplus "/as sysdba"


6. 执行以下语句登录xx数据库,用户名:xx,密码:xx(请输入当地实际密码)
 conn xx/xx;


7. 执行以下语句打开被禁止的触发器


alter table A enable all triggers;


commit;
  • 2
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值