Oracle数据库truncate table后恢复原来数据的方法,留着万一用得
概述:北京某国企客户 Oracle 11g R2 数据库误truncate table CM_CHECK_ITEM_HIS,表数据丢失,业务查询到该表时报错,此时发现数据库的备份不能用,表数据无法查询。
客户Oracle 11g R2 数据库误truncate table CM_CHECK_ITEM_HIS,表数据丢失,业务查询到该表时报错,此时发现数据库的备份不能用,表数据无法查询。 数据恢复过程为保护用户数据,本文档构造与客户相同的故障。Scott用户创建表emp1,复制emp表,连续复制多次,总记录数为:7340032条。truncate表emp1,之后没有进行任何操作。查询该表,数据库中该表的记录为0条。 注: Os:win server 2008R2。数据库版本:win_oracle_11.2.0.1_x64; 1 对system表空间文件进行分析,找到truncate表的原始数据所在的位置 图二: 2 解析表所在的数据文件数据库,找到truncate的数据 3 将truncate的数据库插入到数据库中 数据恢复结果通过解析system01.dbf文件,找到truncate的数据所在的位置,找到被删除的数据。解析表所在的数据文件,将truncate的数据插入到数据库中。 Exp导出scott用户; 图四: (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |