当前位置:  数据库>oracle

Oracle中利用undo进行数据的恢复操作

    来源: 互联网  发布时间:2017-06-20

    本文导语: 【说明】无意中看到一个同事的QQ留言上面写着“真累“,还没有过30分钟就接到这个同事的电话,如下:刚在做删除数据的时候,发现由于条件没有写好,导致删错了,有没有办法恢复;接到这个任务 ,首先是深深的感慨了一...

【说明】无意中看到一个同事的QQ留言上面写着“真累“,还没有过30分钟就接到这个同事的电话,如下:刚在做删除数据的时候,发现由于条件没有写好,导致删错了,有没有办法恢复;接到这个任务 ,首先是深深的感慨了一下:人在状态不好的情况下尽量多休息少做事,特别是涉及到很重要的事情。

跟着同事确定了出现问题的时间点后,先是安慰一下,让他从那惶恐不安的心里恢复过来,然后开始了找寻数据的工作。

【环境说明】

•数据库版本:11.2.0.3

•数据库闪回:未开启

【恢复步骤】

【1】确定用户删除数据的时间点和脚本,对于数据的恢复有很大的帮助,最好再对比下用户电脑上面的时间和服务器上面的时间差,查询的时候需要补上时间差(经检查服务器的时间和用户电脑的时间相差5分钟)

用户反馈客户端上面操作的时间时17:35分,但是服务器的时间落后用户的时间5分钟,所以查询脚本如下:

select * from t_original_archives as of timestamp to_timestamp('2015-11-17 17:30:00','YYYY-MM-DD HH24:MI:SS')  where  id=1974244

【2】把数据导出让用户进行检查

create table t_original_archives_bak as select * from t_original_archives as of timestamp to_timestamp('2015-11-17 17:30:00','YYYY-MM-DD HH24:MI:SS')  where id=1974244;

【3】确认没有问题后变可以把误删除的数据插入到原来的表中。

insert into t_original_archives select * from t_original_archives_bak

经过以上步骤,又一次拯救了一次数据灾难;

整个恢复的过程中对于误删除时间的控制最为重要,一般15分钟之内的数据库可以找到,超过15分钟的话要看天吃饭了。

以下是闪回查询的原理。

Oracle数据库的undo表空间用于存放数据删除前的前镜像,保证了数据的读一致性。所以数据被更新或删除的时候,数据并没有马上消失,而是会放在undo表空间里面的。

SQL>  show parameter undo;

NAME                                              TYPE                      VALUE

------------------------------------ -----------  ------------------------------

_in_memory_undo                          boolean                  FALSE

undo_management                          string                    AUTO

undo_retention                              integer                      900

undo_tablespace                            string                    UNDOTBS1

参数说明:

undo_management = auto,设置自动undo自动管理方式,默认设置为:auto;

undo_retention = n(秒),设置决定undo最多的保存时间,默认是900秒,建议条件允许的情况下可以设置多一些。

注意:并不是说系统一定会保留900秒的前镜像,也不是900秒后保留的前镜像就会消失,跟undo表空间的大小和系统的繁忙程度有关系。(一般情况15分钟之内的数据可以被查询得到的)

该参数的修改方式:SQL> alter system set undo_retention = 1800;

2、怎么保证undo存放的数据的存放时间?

方法:通过使用RETENTION GRARANTEE子句,保证数据库按照undo_retention的时间保留;

2.1 启动保证保留

ALTER DATABASE UNDOTBS01 RETENTION GUARANTEE

2.2 关闭撤销信息的保证保留

ALTER DATABASE UNDOTBS01 RETENTION NOGUARANTEE

3、启用RETENTION GRARANTEE的弊端

当启用了该参数后,业务繁忙的情况下,当undo表空间的使用率100%的情况下,数据库就会宕住,因为要保证undo的镜像不被覆盖,所以就不允许其他DDL语句的继续执行;

4、UNDO表空间大小的设定

方法1:可以根据AWR报告给出的建议来设置UNDO表空间的大小。

方法2:在业务系统高峰期的情况下,随时观察UNDO表空间的使用情况,进行调整。

RMAN备份与恢复之undo表空间丢失

关于Oracle 释放过度使用的undo表空间

Oracle undo的一些理解

Oracle undo 镜像数据探究

Oracle 回滚(ROLLBACK)和撤销(undo)

Linux-6-64下安装Oracle 12C笔记

在CentOS 6.4下安装Oracle 11gR2(x64)

Oracle 11gR2 在VMWare虚拟机中安装步骤

Debian 下 安装 Oracle 11g XE R2


    
 
 

您可能感兴趣的文章:

  • Oracle数据库恢复后心得
  • 关于系统重装后Oracle数据库完全恢复的解决办法
  • oracle drop table(表)数据恢复方法
  • Oracle数据库备份和恢复工具 RMan
  • oracle备份恢复的具体方法
  • oracle中误删除表后恢复语句(FLASHBACK)
  • oracle冷备份恢复和oracle异机恢复使用方法
  • 在Oracle 10gR2中设定指定的恢复点实现轻松闪回
  • Oracle重做日志文件损坏或丢失后的恢复
  • Oracle11g备份和恢复功能的提高
  • 实战Oracle数据库备份与恢复
  • Oracle数据库冷备份的异地恢复
  • oracle下实现恢复一个丢失的数据文件的代码
  • 详解通过Backup Exec来实施Oracle灾难恢复
  • Oracle的恢复管理器及DBMS_JOB包分析
  • Oracle数据库文件恢复以及备份思路
  • Oracle数据库备份恢复最佳实践
  • oracle如何恢复被覆盖的存储过程
  • rman恢复方案和oracle异机恢复
  • oracle数据库创建备份与恢复脚本整理
  • Linux系统下利用java连接Oracle 10G
  • linux c 怎样利用pro*c/c++操作 win2000 下 oracle 谢谢
  • 利用多个转储文件导出大量Oracle数据
  • Oracle利用存储过程造数据
  • 怎样利用JDBC连接oracle数据库?谢谢!!!
  • 利用windows任务计划实现oracle的定期备份
  • 利用ASP来实现Oracle数据记录的分页显示
  • 有关java.sql.ResultSet 利用SetDate往 oracle 中插入时间和日期的问题!!
  • 利用Oracle9i XML DB来解决复杂编码问题
  • C#利用ODP.net连接Oracle数据库的操作方法
  • 利用可更新ResultSet的updateBinaryStream()可以把图片存到mySql数据库,却不能存到Oracle数据库,怎么办?
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • ORACLE日期相关操作
  • Linux下如何用C语言操作Oracle数据库相关的图书推荐
  • Oracle终于涉入支持Linux操作系统了
  • Linux平台下Oracle的操作
  • Window客户端通过ADO是否能够连接和操作Unix平台下的Oracle数据库?
  • Oracle将字符编码从GBK转到UTF8,如何操作比较稳妥?
  • 如何设定linux red hat 9的oracle9,让window的电脑可以操作数据库
  • linux oracle数据库删除操作指南
  • Linux环境中Oracle数据导入与导出备份操作
  • Oracle针对数据库某一行进行操作的时候,如何将这一行加行锁
  • oracle的plsql里有没有位操作的功能
  • fedora core5 (FC5) 下面不能装 Oracle 10g 么? (检查操作系统就通不过啊,晕)
  • Linux操作系统下Oracle数据库多实例启动方式及修改内存
  • 怎样在c语言的代码里内嵌的操作oracle数据库,各位大虾谢谢了
  • 一个关于JAVA操作oracle数据库时UPDATE权限的问题
  • Oracle中操作分页
  • Oracle 数据库操作技巧集
  • secureCRT远程连接服务器操作oracle数据库出现的问题
  • 请教各位:JAVA操作ORACLE的问题 急!!!
  • 学习登录oracle数据库时常用的操作命令
  • Linux平台上OCI操作ORACLE数据库时乱码问题的解决
  • Oracle 12c发布简单介绍及官方下载地址
  • 在linux下安装oracle,如何设置让oracle自动启动!也就是让oracle那个服务自动启动,不是手动的
  • oracle 11g最新版官方下载地址
  • 请问su oracle 和su - oracle有什么不同?
  • Oracle 数据库(oracle Database)Select 多表关联查询方式
  • 虚拟机装Oracle R12与Oracle10g
  • Oracle数据库(Oracle Database)体系结构及基本组成介绍
  • Oracle 数据库开发工具 Oracle SQL Developer
  • 如何设置让Oracle SQL Developer显示的时间包含时分秒
  • Oracle EBS R12 支持 Oracle Database 11g


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3