Oracle数据库数据丢失恢复的几种方法总结数据库数据丢失恢复的几种方法总结
相信大家无论是开发、测试还是运维过程中,都可能会因为误操作、连错数据库、用错用户、语句条件有误等
原因,导致错误删除、错误更新等问题。当你捶胸顿足或吓得腿软时,肯定希望有办法来恢复这些数据。oracle
就提供了一些强大的方法或机制,可以帮到有需要的你。
根据根据oracle数据库的特点和提供的工具,主要方法有以下几种方法:数据库的特点和提供的工具,主要方法有以下几种方法:
1. 利用逻辑备份使用import工具丢失数据的表
2. 利用物理备份来通过还原数据文件并进行不完全恢复
3. 利用dbms_logmnr包从redo log文件中恢复
4. 利用flashback特性恢复数据
前提前提
为了方便使用方法的介绍,上述恢复方法都将基于以下场景进行:系统管理员在前一天晚上11点用export对数据库做了全库逻
辑备份,然后对所有数据文件进行了热备份。第二天上午10点,系统管理员在修改表TFUNDASSET的数据时,由于修改语句
的条件写错了,导致一批记录(几千条)的ztm字段被修改成了错误的值,而且已经提交。这个表是资产表,相对而言数据变
化不频繁。
一、利用逻辑备份使用一、利用逻辑备份使用import工具恢复丢失的数据工具恢复丢失的数据
export/import是oracle提供的用于对数据库进行逻辑备份的工具。该工具适用于备份那些数据量不大、业务量不多的数据库系
统。因为如果在前一天晚上11点用export做了逻辑备份,那么当今天上午10点数据库意外崩溃时,从备份起到数据库崩溃的这
段时间里的数据修改操作(包括DDL和DML)都会丢失。如果丢失数据内的表上的数据是相对比较稳定,也就是说该表上基
本没有DML操作,例如标准代码表、分区表里的历史数据,那么采用import来导入该表可以比较完整的恢复数据。如果该表是
经常变化的业务表,那么这些丢失的数据只能根据业务情况从纸质记录恢复,或者其他途径恢复。
▲示例如下:这个表是一个资产表。相对来说,今天系统运行中修改的数据较少,丢失的数据量可以承受或者可以从别的途径
恢复。那就可以用import来恢复。
方法一:方法一:
1、把这个表的数据备份到另一个表:
2、删除该表的记录:
3、执行下面的命令:
这个命令中在关键字tables中指定需要导入的表名字,ignore=y表示忽略表已经存在的错误。
4、导入结束后,检查表中的记录,并用适当的方法恢复当天的修改。
方法二:方法二:
1、 把需要恢复的表导入到另一个用户下面:
2、检查数据以后,把原表记录删除:
3、然后从另一用户表中插入回去: