通常我们操作数据库时可能会对数据库进行了一些错误的操作,做常见的是不小心将表中的数据给删除了或是直接将表给drop了。其实,这些操作后,我们都是可以进行数据恢复的,这里是我进行了一些实验,简单的恢复操作。
1、如果我们将表给删了怎么办?
在这里我们做一个实验
新建一张表t_user
create table t_user(
username varchar2(20) primary key,
age varchar2(10)
)
插入两条数据:
insert into t_user values('zzzz','1');
insert into t_user values('xxxx','2');
查看一下:
select * from t_user;
结果是:
zzzz 1 XX U
xxxx 2 XX U
我们继续操作
drop table t_user;
这事再去查询数据库时,没有了t_user这张表了。
但是我们想恢复这张表怎么办呢?
我们可以利用闪回,命令是这样的
flashback table t_user to before drop;
ok,再去查询一下t_user表,这个表以及表中的数据又存在了。
2、我们最常见的是删除了表中的数据,也就是truncate或是delete操作。
这是我们需要将闪回到删除之前的数据库看看
命令是:
(1)select * from t_user as of timestamp sysdate - 5/1440;
(2)select * from t_user as of timestamp(systimestamp-interval '1' minute);
这里的时间参数我们是可以设置的
在这里我们就可以看到我们删除数据之前的表的数据,接下来的操作就很简单了,我们就在上述命令前直接加上:insert into t_user就Ok了。
这些都是闪回能给我们带来的帮助,但是
注意:如果需要闪回一个表,需要以下条件:
·需要有flashback any table的系统权限或者是该表的flashback对象权限;
·需要有该表的select,insert,delete,alter权限;
·必须保证该表row movement。
如果希望能闪回数据库,需要设置如下参数:DB_RECOVER_FILE_DEST --日志的存放位置,
DB_RECOVER_FILE_DEST_SIZ --E恢复区的大小
在创建数据库的时候,Oracle将自动创建恢复区,但默认是关闭的,需要执行alter database flashback on命令。
执行Flashback Database命令格式:
SQL>flashback database to time to_timestamp(xxx);
SQL>flashback database to scn xxx
数据库的闪回状态可以从V$database视图中查询得到:
SQL> select dbid,name,flashback_on,current_scn from v$database;
DBID NAME FLASHBACK_ON CURRENT_SCN
---------- --------- ------------------ -----------
1692001961 ACF NO 8175168
分享到:
相关推荐
Oracle恢复误删除数据,解除锁定的等SQL语句
Oracle必杀技物理删除数据文件恢复,详解了实用的Oracle物理表空间删除修复命令。
Oracle恢复误删除数据 Oracle恢复误删除数据 Oracle恢复误删除数据
详细介绍如何正常删除Oracle 数据库表空间数据文件,OFFLINE和OFFLINE DROP的区别,OS级别删除了数据文件后的恢复,删除数据库表空间数据文件演示示例
原创Oracle 物理删除数据文件恢复 危机演练
oracle 恢复表数据 可以恢复刚删除的数据
Oracle从回收站恢复删除的表的数据,以及其他sql优化语句
SCN提供了Oracle的内部时钟机制,可被看作逻辑时钟,这对于恢复操作是至关重要的 注释:Oracle 仅根据 SCN 执行恢复。 它定义了数据库在某个确切时刻提交的版本。在事物提交时,它被赋予一个唯一的标示事物的SCN ...
因自己前段时间因truncate一张表无法找回,且数据超过60W,平常的企业软件超过1W收费,故整理此内容,希望和我遇到同样问题的新手有帮助
找回时操作的数据库为oracle 10g , 之前删除方式为delete
Oracle数据库误删除数据的不同恢复方法整理(超级实用)
oracle误删除表数据后的恢复详解.doc
ORACLE 表删除 后还原的几种办法 通过oracle提供的回闪功能:oracle保存在回滚保持段里的数据时间有一定的时间限制由undo_retention 这个参数值。。等等。。
pl/sql,Oracle数据库中,不小心delete数据并提交后如何恢复被删数据? 提供了两种办法
oracle误删数据恢复。利用ORACLE回闪功能时间点克查询删除前的数据,如何恢复就看自己了哈
oracle中数据delete且commit 恢复误删数据
利用oracle提供的闪回方法,如果在删除数据后还没做大量的操作(只要保证被删除数据的块没被覆写),就可以利用闪回方式直接找回删除的数据。
******此处的操作需要对windows操作系统注册表非常熟悉,对于linux平台,恢复操作类似,只不过需要对环境变量的操作熟悉。 3、监听程序的恢复 a、配置参数的恢复,oracle_home\network\admin\listener.ora,检查...
Oracle数据库表数据误删还原的方法,在一定时间内表数据误删除了恢复数据的方法
利用oracle闪回技术恢复数据,在因误操作导致删除数据时,可以进行数据恢复。