首页 > 数据库 >数据库数据恢复-Oracle数据库误执行truncate table的数据恢复案例

数据库数据恢复-Oracle数据库误执行truncate table的数据恢复案例

时间:2023-09-11 15:36:45浏览次数:47  
标签:数据恢复 truncate 数据库 emp1 Oracle 数据

Oracle数据库故障&分析:

北京某单位Oracle 11g R2数据库误执行truncate  table  CM_CHECK_ITEM_HIS,表数据丢失,查询该表时报错。数据库备份无法使用,表数据无法查询。

Oracle数据库Truncate数据的机理:执行Truncate命令后,ORACLE数据库会在数据字典和Segment Header中更新表的Data Object ID,但是不会修改实际数据部分的块。Truncate数据会导致数据字典和Segment Header的DATA_OBJECT_ID与后续的数据块中的不一致,ORACLE服务进程在读取全表数据时就不会读取到已经被TRUNCATE的记录,实际数据其实并没有被覆盖。


Oracle数据库数据恢复过程:

为了保护用户隐私和数据安全,我们没有将恢复该oracle数据库数据的过程演示出来,北亚企安数据恢复工程师还原了和该案例相同的oracle故障环境,用来演示如何恢复Oracle数据库Truncate数据。

1、通过Scott用户创建表emp1,连续复制emp表多次,总记录数为7340032条。truncate表emp1,之后没有进行任何增删改的操作。经过查询,Oracle数据库中表emp1的记录为0条。

数据库数据恢复-Oracle数据库误执行truncate  table的数据恢复案例_数据恢复

2、分析system表空间文件,找到truncate表(表emp1)的原始数据所在的位置。

数据库数据恢复-Oracle数据库误执行truncate  table的数据恢复案例_oracle数据恢复_02

3、解析表emp1所在的数据文件,找到truncate的数据。

4、将truncate的数据插入到数据库中。


Oracle数据库数据恢复结果:

解析system01.dbf文件,找到truncate的数据所在的位置,找到被删除的数据。解析truncate表所在的数据文件,将truncate的数据插入到数据库中。

这时在oracle数据库中查找被truncate的表,发现数据已经回来了,备份数据。

数据库数据恢复-Oracle数据库误执行truncate  table的数据恢复案例_数据库数据恢复_03

Exp导出scott用户。

数据库数据恢复-Oracle数据库误执行truncate  table的数据恢复案例_oracle数据恢复_04

标签:数据恢复,truncate,数据库,emp1,Oracle,数据
From: https://blog.51cto.com/sun510/7436076

相关文章

  • Navicat 携手华为云GaussDB,联合打造便捷高效的数据库开发和建模工具方案
    本文分享自华为云社区《Navicat携手华为云GaussDB,联合打造便捷高效的数据库开发和建模工具方案》,作者:GaussDB数据库。近日,NavicatPremium顺利完成与华为云GaussDB的兼容性测试认证,并获得华为云授予的技术认证书。Navicat作为华为云GaussDB生态工具合作伙伴以及G......
  • 数据库----初识
    《世界诞生的前夜----开发环境配置》在进入数据库开发软件时遇到这样一个错误:  看起来是SQLServer(数据库管理系统)发生了错误,  找到数据库管理系统设置工具,让SQLServer运行起来就行了......
  • ClickHouse使用之二 ——整合mysql,实现数据库创建查询导出
    1.mysql创建一个用于clickhouse的账号mysql_clickhouse并且授权CREATEUSER'mysql_clickhouse'@'%'IDENTIFIEDBY'Password123!';GRANTALLPRIVILEGESON*.*TO‘mysql_clickhouse’@‘%';2. 使用mysql引擎创建一个clickhouse的外部表存在一个mysql的数据库:host:......
  • Debezium日常分享系列之:Oracle数据库系列文章之安装和设置
    Debezium日常分享系列之:Oracle数据库系列文章之安装和设置一、什么是Oracle二、安装Oracle三、配置Oracle1.配置Oracle:归档日志2.配置Oracle:重做日志3.配置Oracle:补充日志记录4.配置Oracle:用户设置四、总结这篇文章是由3部分组成的系列文章的一部分,该系列文章探讨如何使用......
  • PostgreSQL数据库从入门到精通系列之五:深入理解lsn_proc、lsn_commit、lsn、txId、ts_
    PostgreSQL数据库从入门到精通系列之五:深入理解lsn_proc、lsn_commit、lsn、txId、ts_usec一、深入理解lsn_proc二、深入理解lsn_commit三、深入理解lsn四、深入理解txId五、深入理解ts_usec一、深入理解lsn_proc在PostgreSQL中,lsn_proc是一个内置函数,用于将逻辑日志位置(LSN)转换......
  • PostgreSQL数据库从入门到精通系列之六:深入理解逻辑复制槽,创建逻辑复制槽,删除逻辑复制
    PostgreSQL数据库从入门到精通系列之六:深入理解逻辑复制槽,创建逻辑复制槽,删除逻辑复制槽一、逻辑复制槽二、创建逻辑复制槽三、删除逻辑复制槽一、逻辑复制槽在PostgreSQL中,逻辑复制槽是一种用于实现逻辑复制的功能。逻辑复制槽允许将源数据库的更改流式传输到目标数据库,并使目标......
  • Mysql数据库系列之:深入理解tinyint(n)
    Mysql数据库系列之:深入理解tinyintn一、深入理解tinyint(n)二、创建包含tinyint类型字段的表三、扩展一、深入理解tinyint(n)对于MySQL中的tinyint列,"(n)"没有任何实际意义。在MySQL中,tinyint的宽度始终为1字节,所以在定义表时指定tinyint(n)与tinyint相同。在MySQL中,tinyint字段......
  • NoSQL 非关系型数据库
    NoSQL非关系型数据库NotOnlySQL(不仅仅是SQL)NoSQL用于超大规模数据的存储.NoSQL数据库分类构建高性能性和伸缩性,代价是查询灵活性差规模较小,访问模式未知的小项目用SQL大型项目,规模很大,需要关系查询,推荐SQL小项目不推荐使用NoSQL......
  • 数据库基础面试第三弹
    1.mysql数据库四种常见数据库引擎1.MyISAM:MyISAM是MySQL最早的数据库引擎之一。它被设计成处理大量的插入和查询操作。MyISAM表格的数据存储在三个文件上:.frm文件存储表结构,.MYD文件存储数据,.MYI文件存储索引。MyISAM表格不支持事务处理和崩溃恢复,因此在并发写入操作和故障发......
  • easyrecovery 2023年最好用的数据恢复软件
    EasyRecovery是一款操作简单、功能强大数据恢复软件,通过easyrecovery可以从硬盘、光盘、U盘、数码相机、手机等各种设备中恢复被删除或丢失的文件、图片、音频、视频等数据文件。easyrecovery数据恢复软件,是国内顶尖工作室的技术杰作。它是一个硬盘数据恢复工具,能够帮你恢复丢失的......