浏览 2237 次
锁定老帖子 主题:恢复当天删除的数据
精华帖 (0) :: 良好帖 (0) :: 新手帖 (0) :: 隐藏帖 (0)
|
|
---|---|
作者 | 正文 |
发表时间:2011-12-23
12月2日,我误删了数据库,老大很不爽,命我再30分钟之内恢复,情急之下,写了一个存储过程,适用于恢复当天删除了表而没有记住表的名称。 只需要传入当天的时间,调用一下就ok了。 存储过程如下: create or replace procedure proc_databack (deletetime in varchar2) as --把当天已经删除的信息查询出来放入游标 cursor mycursor is(select object_name from recyclebin where droptime like deletetime); temp_emp varchar2(2000); vflash_back varchar2(2000); begin open mycursor; loop fetch mycursor into temp_emp; exit when mycursor%notfound; --构建恢复语句 vflash_back:='flashback table "'||temp_emp||'" to before drop'; --循环恢复被删除的表,直到全部恢复完成 execute immediate vflash_back; end loop; close mycursor; end; --调用存储过程 --比如今天是2011-12-02,那么写法如下: /* declare time varchar2(20); begin time:='2011-12-02%'; proc_databack (time); end; */
声明:ITeye文章版权属于作者,受法律保护。没有作者书面许可不得转载。
推荐链接
|
|
返回顶楼 | |