今天小编给大家分享一下Oracle怎么使用fy_recover_data恢复truncate删除的数据的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这
今天小编给大家分享一下Oracle怎么使用fy_recover_data恢复truncate删除的数据的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。
前言
TRUNCATE不会逐个清除用户数据块上的数据,而仅仅重置数据字典和元数据块上的元数据(如存储段头和扩展段图)。也就是说,此时,其基本数据并未被破坏,而是被系统回收、等待被重新分配。
如果我们已经有一套元数据及数据块,然后将被TRUNCATE的用户数据块的内容取代其用户数据块的内容,是否可以“骗”过Oracle,让它读出这些数据呢? 回顾一下表扫描的过程,这个方法应该是可行的。我们只要想办法构造出一个结构相同、且具有完整元数据信息和格式化了的用户数据块的傀儡表对象,然后将被TRUNCATE的用户数据块找出,再将其数据内容部分嫁接到傀儡对象的用户数据块,使Oracle以外这是傀儡对象的数据,就能让Oracle扫描并读出数据内容。
1.创建测试表
SQL> create table pak_tab as select * from dba_objects; Table created. SQL> select count(*) from pak_tab; COUNT(*) ---------- 86262
2.truncate table pak_tab
SQL> truncate table pak_tab; Table truncated. SQL> select count(*) from pak_tab; COUNT(*) ---------- 0 SQL> select owner from sys.pak_tab where rownum<=1; OWNER ------------------------------ SYS
3 编译fy_recover_data包
SQL> @fy_recover_data.pck Package created. Package body created.
4.执行fy_recover_data包
SQL> exec fy_recover_data.recover_truncated_table('sys','pak_tab'); PL/SQL procedure successfully completed. SQL> SELECT COUNT(*) FROM pak_tab; COUNT(*) ---------- 0 SQL> SELECT COUNT(*) FROM pak_tab$$; COUNT(*) ---------- 86262
5.把数据插回原表
SQL> alter table pak_tab nologging; Table altered. SQL> insert /*+append*/ into pak_tab select * from pak_tab$$; 86262 rows created. SQL> commit; Commit complete. SQL> alter table pak_tab logging; Table altered.
6.校验数据
SQL> select count(*) from pak_tab; COUNT(*) ---------- 86262
以上就是“Oracle怎么使用fy_recover_data恢复truncate删除的数据”这篇文章的所有内容,感谢各位的阅读!相信大家阅读完这篇文章都有很大的收获,小编每天都会为大家更新不同的知识,如果还想学习更多的知识,请关注恰卡网行业资讯频道。
本站部分文章来自网络或用户投稿,如无特殊说明或标注,均为本站原创发布。涉及资源下载的,本站旨在共享仅供大家学习与参考,如您想商用请获取官网版权,如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。