教你应对Oracle检索数据的一致性以及回滚数据
2009-06-30 05:08:00 来源:WEB开发网核心提示:2.回滚数据(事务恢复)1.当用户updata数据但还没有提交SQL> select * from c;A B-- -1 103 4SQL> update c set b=2 where a=1;SQL> select * from c;A B-- -1 23 4这时用户突然后悔了,想恢复到原来的状态
2.回滚数据(事务恢复)
1.当用户updata数据但还没有提交
SQL> select * from c;
A B
---------- -----------------------------
1 10
3 4
SQL> update c set b=2 where a=1;
SQL> select * from c;
A B
---------- -----------------------------
1 2
3 4
这时用户突然后悔了,想恢复到原来的状态
SQL> rollback;
Rollback complete.
SQL> commit;
SQL> select * from c;
A B
---------- -----------------------
110
3 4
可见当用户用命今rollback还能回滚到初始状态。
2.当用户updata数据且已提交
当用户updata数据且已提交后,可以根据SCN记录把数据还源。
先查看原始数据
SQL> select * from c;
A B
---------- ----------
110
3 4
找到SCN
SQL> select current_scn from v$database;
CURRENT_SCN
-----------
693636
现在删除表中的数据并提交
SQL> delete from c;
2 rows deleted.
SQL> commit;
Commit complete.
查询(现在表中已没有数据了)
SQL> select * from c;
no rows selected
检索特定SCN的数据
SQL> select * from c as of scn 693636;
A B
---------- ----------
110
3 4
恢复数据
SQL> insert into c select * from c as of scn 693636;
2 rows created.
SQL> commit;
Commit complete.
现在再查询
SQL> select * from c;
A B
---------- ----------------------
110
3 4
可见可以根据SCN恢复到某一检查点的数据,如果把SCN转换成时间,,就可以把数据恢复到某一时间点。
- ››oracle 中 UPDATE nowait 的使用方法
- ››Oracle ORA-12560解决方法
- ››Oracle 10g RAC 常用维护命令
- ››Oracle如何在ASM中定位文件的分布
- ››Oracle的DBMS_RANDOM.STRING 的用法
- ››oracle 外部表导入时间日期类型数据,多字段导入
- ››Oracle中查找重复记录
- ››oracle修改用户登录密码
- ››Oracle创建删除用户、角色、表空间、导入导出等命...
- ››Oracle中登陆时报ORA-28000: the account is lock...
- ››Oracle数据库在配置文件中更改最大连接数
- ››Oracle中在pl/sql developer修改表的两种方式
更多精彩
赞助商链接