首页数据库oracle中commit之后进行数据回滚的方法

oracle中commit之后进行数据回滚的方法

时间2024-02-28 18:33:03发布访客分类数据库浏览220
导读:收集整理的这篇文章主要介绍了oracle中commit之后进行数据回滚的方法,觉得挺不错的,现在分享给大家,也给大家做个参考。 commIT之后第一种:记住大概的时间,获取前大概时间的数...
收集整理的这篇文章主要介绍了oracle中commit之后进行数据回滚的方法,觉得挺不错的,现在分享给大家,也给大家做个参考。

commIT之后

第一种:

记住大概的时间,获取前大概时间的数据。

select * From test as of timestamp to_timestamp('2021-12-08 09:30:56','yyyy-mm-dd hh24:mi:ss');
    

上面的代码就可以查看你要恢复的时间点的记录,看看是不是有你想要的刚刚提交的DML相关记录。

能看到,剩下的就简单了,可以把现在表中的数据备份到一个临时表,然后把记录插进去原表就行了

不要用truncate删除,不然你就回不去了,到时候你就又要哭了。

delete from Test;
    insert into Test select * from Test as of timestamp to_timestamp('2021-12-08 09:30:56','yyyy-mm-dd hh24:mi:ss');
    commit;
    

第二种:

oracle在9i版本的时候引入了闪回技术,在Oracle 10g已经全面提供了闪回功能,主要提供了快速简单恢复数据库误操作的数据的恢复方法,而不用从逻辑备份或物理备份中恢复过来。

如果多次commit数据后,那可不可以闪回呢?貌似不可以。闪回只能暂存最近一次的数据操作。
闪回执行步骤: 

  1.查询最近更新数据之前的数据(以便确定是不是Commit之前的数据)

select * from Test as of timestamp to_timestamp('2021-12-08 08:00:00', 'yyyy-mm-dd hh24:mi:ss');
    

  其中Test为被误操作的表,'2021-12-08 08:00:00'表示上次更新数据前的时间,

  2.闪回操作前启用行移动功能(不启用不可以闪回)

ALTER TABLE Test enable row movement;
    

  其中Test表示被误操作的表 

  3.执行闪回语句:

flashback table Test to timestamp TO_TIMESTAMP('20211208 15:10:00','YYYYMMDD HH24:MI:SS');
    

  这样被误操作的数据就可以“找”回来了。哈哈~

注:方法来源于网络整理,请谨慎操作!!!修改数据前养成好习惯,手动备份下数据!

到此这篇关于oracle中commit之后如何进行回滚的文章就介绍到这了,更多相关oracle中commit之后如何进行回滚内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!

您可能感兴趣的文章:
  • Oracle Form中COMMIT的概述及使用技巧
  • Oracle数据回滚的全过程
  • @L_304_2@
  • Oracle回滚段的概念,用法和规划及问题的解决

声明:本文内容由网友自发贡献,本站不承担相应法律责任。对本内容有异议或投诉,请联系2913721942#qq.com核实处理,我们将尽快回复您,谢谢合作!


若转载请注明出处: oracle中commit之后进行数据回滚的方法
本文地址: https://pptw.com/jishu/631790.html
Oracle进阶DECODE函数使用详解 解决plsql因事务未提交造成的锁表问题

游客 回复需填写必要信息