oracle 误删除数据之后的处理

 
1/数据恢复到具体的某个时间点以前的数据
employees_test   只是误操作的表的表名 

 flashback table employees_test    to timestamp  to_timestamp ('2012-08-02 19:12:20','yyyy-mm-dd hh24:mi:ss');  


 2、如果上面的脚本不能执行,先执行如下脚本


ALTER TABLE employees_test   ENABLE ROW MOVEMENT;  



如果执行了步骤2、再执行1后报回滚段不够,错误信息如下:

 ORA-01555: 快照过旧: 回退段号 11 (名称为 "_SYSSMU11_4182116359$") 过小

需要查看下回滚时间段保留长时间


17 SQL> show parameter undo
18 
19 NAME                     TYPE       VALUE
20 -------------------- ----------- --------------
21 undo_management          string      AUTO
22 undo_retention           integer     900
23 undo_tablespace          string      UNDO2
24 SQL> create undo tablespace undo1 datafile '/u01/app/oracle/oradata/yft/undo01.dbf' size 1m;

 
  
 
  
这就表示只保留900秒,是oracle默认保留的时间长度
22 undo_retention           integer     900

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值