误操作导致数据库数据失落是最常见的数据库故障。如果有最新备份的状况下,误删除数据后复原备份数据即可。当然也会有非凡情况如:数据库备份无奈应用、还原报错等。北亚数据恢复工程师为大家介绍的是一例 oracle 数据库误 truncate table 后的数据库复原案例。如果您碰到误操作导致数据失落,备份又恰好无奈应用的状况能够参考这个数据恢复计划。
Truncate 工作原理:
失常状况下 oracle 会通过 Segment Header 及数据字典对表的 Data Object ID 进行更新,具体到存储数据局部的块实际上并未被批改。在 oracle 服务在进行全表数据读取时,因为数据字典和 Data Object ID 与理论存储的数据块内容不统一,而不会读取到被 truncate 的内容记录,这也就是数据库复原数据的要害。
数据库数据恢复过程:
在本案例演示中,北亚数据恢复工程师结构了一个故障。
1、结构故障的软硬件设施如下:
Os:windows server;
数据库版本:最新版本的 64 位的 win_oracle。
2、Scott 用户创立表 emp1,复制 emp 表,间断复制屡次,总记录数为:7340032 条。随后 truncate 表 emp1。此时查问该表,数据库中该表的记录为 0 条。见下图:
3、北亚数据恢复工程师关上数据库文件的底层数据,对 system 表空间文件进行剖析,找到 truncate 表的原始数据所在的地位,见下图:
4、解析表所在的数据文件数据库,找到 truncate 的数据;
5、将 truncate 的数据库插入到数据库中。
数据恢复后果:
通过解析 system01.dbf 文件,北亚数据恢复工程师找到 truncate 的数据所在的地位,找到被删除的数据。解析表所在的数据文件,将 truncate 的数据插入到数据库中。
在数据库中,查找被 truncate,发现数据回来了,间接备份数据。见下图:
Exp 导出 scott 用户;见下图: