【北亚数据恢复】oracle数据库执行truncate table命令怎么恢复数据()
误操作导致数据库数据丢失是最常见的数据库故障。如果有最新备份的情况下,误删除数据后恢复备份数据即可。当然也会有特殊状况如:数据库备份无法使用、还原报错等。北亚数据恢复工程师为大家介绍的是一例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的数据库插入到数据库中。
【【北亚数据恢复】oracle数据库执行truncate table命令怎么恢复数据()】数据恢复结果 :
通过解析system01.dbf文件,北亚数据恢复工程师找到truncate的数据所在的位置,找到被删除的数据。解析表所在的数据文件,将truncate的数据插入到数据库中。
在数据库中,查找被truncate,发现数据回来了,直接备份数据。见下图:
文章图片
Exp导出scott用户;见下图:
文章图片
推荐阅读
- 黄东旭( 关于基础软件产品价值的思考)
- 手把手教你移植蜂鸟E203 hbridv2【集创芯来RISC-V杯】
- Java|Java 替换PDF中的字体
- 【小镇的技术天梯】lanmp服务器集群搭建(1)nginx的反向代理
- 【小镇的技术天梯】lanmp服务器集群搭建(4)mysql-cluster集群搭建
- python|有趣好玩的python编程网站
- python|【python基础教程】面向对象初识
- python爬虫|【python爬虫教程】请求模块urllib的基本使用
- python|【python基础教程】python常见的运算符及用法
- 编程语言|现代编程语言(zig)