热门标签 | HotTags
当前位置:  开发笔记 > 数据库 > 正文

Oracle10g恢复操作概述

1.实例恢复在实例重新启动时,系统自动恢复。判断依据:数据文件的scn与控制文件不一致。步骤:(1)使用onlineredolog,数据前

1. 实例恢复在实例重新启动时,系统自动恢复。判断依据:数据文件的scn与控制文件不一致。步骤:(1)使用online redo log,数据前

1. 实例恢复
在实例重新启动时,系统自动恢复。
判断依据:数据文件的scn与控制文件不一致。
步骤:
(1)使用online redo log,数据前滚到与控制文件一致的SCN处。
(2)使用undo表空间,对未提交事务执行回滚操作。
结果:数据库中数据保留到实例异常前最后一次提交的内容。

2. 用户错误恢复

用户错误包括:用户数据错误修改,数据表误删等
恢复技术:闪回查询(Flashback Query)
Flashback Drop和表空间回收站(Tablespace's recycle bin)
闪回表(Flashback Table)
LogMiner

2.1 闪回查询

前提:undo表空间足够容纳用户在一段时期内修改的数据
undo表空间保留历史修改数据的时限(UNDO_RETETION初始变量)

查询表employees在15分钟前的数据:

SELECT employee_id, last_name, email FROM hr.employees
AS OF TIMESTAMP(systimestamp - interval '15' minute)
WHERE employee_id = 101;

查询表employees在指定历史时间的数据:

SELECT employee_id, last_name, email FROM hr.employees
AS OF TIMESTAMP(
to_timestamp('01-Sep-04 16:18:57.84', 'DD-Mon-RR HH24:MI:SS.FF'))
WHERE employee_id = 101;

2.2 Flashback Drop和表空间回收站

每个Oracle表空间中存在一个Recycle bin,用户存放删除的表和表相关内容(索引等)
删除的表所占用的空间并不立即回收,但在视图DBA_FREE_SPACE中可看到。

# 恢复已删除的数据表到删除前状态(包括表中数据):

SQL> FLASHBACK TABLE order_items TO BEFORE DROP;

# 恢复已删除的数据表并改名:
SQL> FLASHBACK TABLE order_items TO BEFORE DROP RENAME TO order_items_old;

如果同一个表被删除恢复多次,如果需要恢复到以前的版本,则可以查询视图RECYCLEBIN
或者使用命令SHOW RECYCLEBIN,并使用其中的表名称。

使用限制:
仅能用于非系统本地管理的表空间。
位图联合索引、参照完整性约束、物化视图删除后无法保存在Recyclebin.
使用Drop Index删除索引,删除的索引不会保存(只有删除表,,县官索引才保存)。


2.3 Flashback表

允许将一个或多个表恢复到历史指定时间的状态。无需使用太耗时的操作。
Flashback Table使用对相关事务的Undo操作恢复表,使用undo表空间。
(Flashback Drop直接回收恢复表占用的空间)
需要启用行迁移(row movement)功能。undo操作可能会改变记录的rowid.

#启用Row Movement
SQL> ALTER TABLE hr.employees ENABLE ROW MOVEMENT;

#使用Flashback Table恢复表到指定时间
SQL> FLASHBACK TABLE hr.employees [, ...]
TO TIMESTAMP systimestamp - interval '15' minute;

2.4 LogMiner

从Redo Log中提取所有的DDL和DML活动的语句。
使用V$LOGMNR_CONTENTS视图查看(首先需要执行DBMS_LOGMNR.START_LOGMNR()过程)
LogMiner工具本身不能用于恢复数据库
仅从RedoLog中提取用于恢复数据库的SQL语句。

3. 控制文件恢复

如果有控制文件发生错误,Oracle实例将停止运行。
如果没有停止,则必须手动执行:SHUTDOWN ABORT

将未损坏的控制文件复制一份到目标地址,并修改初始化参数中出问题的
控制文件的路径到新的控制文件
或者在初始化参数中把有问题的控制文件条目删除。
控制文件错误时,修改初始化参数参数,需要在NOMOUNT状态下。

SQL> SHUTDOWN IMMEDIATE;
SQL> STARTUP NOMOUNT;
SQL> SHOW PARAMETER CONTROL_FILES;

SQL> SELECT name, value FROM v$spparameters
WHERE name = 'control_files';
SQL> ALTER SYSTEM SET CONTROL_FILES='...','...','...' SCOPE=SPFILE;
SQL> SHUTDOWN IMMEDIATE;
SQL> STARTUP;

4. 重做日志恢复

只要有一组中还有一个Redo Log文件还有可用,Oracle实例就不会崩溃。
(即一个redo log组中所有redo log文件全部失效,Oracle示例就会崩溃)
使用V$LOGFILE视图查询当前redo log文件的状态。

如果一个redo log组中存在错误的redo log文件,那么按以下步骤恢复:

# 确认哪个文件出现错误(在哪个组中)
SQL> SELECT * FROM v$logfile ORDER BY group#;

# 对该组redo log执行归档操作
SQL> ALTER SYSTEM ARCHIVE LOG GROUP ;

# 清空有问题的redo log组并重建
SQL> ALTER DATABASE CLEAR LOGFILE GROUP ;

5. 系统关键数据文件恢复

包括SYSTEM表空间和UNDO表空间。

5.1 NOARCHIVELOG 模式下

只能依赖于是否对数据库有全备份,如果有,则只能恢复到全备份时。

5.2 ARCHIVELOG 模式下

SQL> SHUTDOWN ABORT; # 强制停止
SQL> STARTUP MOUNT; # 只能在Mount状态下恢复

在EM的Perform Recovery中,选择恢复数据文件,以及对应的SYSTEM表空间数据文件。
并可指定需要恢复到的目标路径。系统将会执行RMAN脚本进行恢复。

SQL> ALTER DATABASE OPEN; # 恢复完毕后打开数据库

6. 非系统数据文件恢复

6.1 NOARCHIVELOG 模式下

只能依赖于是否对数据库有全备份,如果有,则只能恢复到全备份时。

6.2 ARCHIVELOG 模式下

只影响到丢失的数据文件相关的数据库对象。
同样可在EM中,按步骤执行Perform Recovery进行恢复。

# 查看数据文件
SQL> SELECT t.name, d.name FROM v$tablespace t
JOIN v$datafile d USING (ts#)
WHERE t.name = 'USERS';

也可以执行RMAN命令恢复编号为4和7的数据文件:

$ rman target /
RMAN> run { sql 'alter database datafile 4 offline';
sql 'alter database datafile 7 offline';
restore datafile 4, 7;
recover datafile 4, 7;
sql 'alter database datafile 4 online';
sql 'alter database datafile 7 online'; }


推荐阅读
  • C# 中创建和执行存储过程的方法
    本文详细介绍了如何使用 C# 创建和调用 SQL Server 存储过程,包括连接数据库、定义命令类型、设置参数等步骤。 ... [详细]
  • 本文介绍如何通过整合SparkSQL与Hive来构建高效的用户画像环境,提高数据处理速度和查询效率。 ... [详细]
  • 探讨密码安全的重要性
    近期,多家知名网站如CSDN、人人网、多玩、开心网等的数据库相继被泄露,其中大量用户的账户密码因明文存储而暴露无遗。本文将探讨黑客获取密码的常见手段,网站如何安全存储用户信息,以及用户应如何保护自己的密码。 ... [详细]
  • 本文详细介绍了如何调整 Kettle 的内存配置以优化性能,并指导用户如何正确设置日志输出中的时间类型,确保数据处理和监控的准确性。 ... [详细]
  • JavaScript 实现图片文件转Base64编码的方法
    本文详细介绍了如何使用JavaScript将用户通过文件输入控件选择的图片文件转换为Base64编码字符串,适用于Web前端开发中图片上传前的预处理。 ... [详细]
  • POJ2263是一个经典的图论问题,涉及寻找从起点到终点的最大载重路径。本文将详细介绍该问题的背景、解题思路及代码实现。 ... [详细]
  • 探讨了在VB中使用WebBrowser控件时遇到的‘无法找到或打开C:\WINDOWS\system32\ieframe.dll’问题,并提供了解决方案。 ... [详细]
  • 最近在博客园上发现了一款ViewState解码工具,这是一款非常实用的工具,可以帮助开发者检查ViewState是否正确保存。然而,这也意味着其他人可以通过该工具查看ViewState中的数据,因此隐藏ViewState变得尤为重要。 ... [详细]
  • 使用 jQuery 实现页面加载进度条
    页面加载进度条是提升用户体验的重要工具,通过在页面头部显示一个加载状态,并在页面完全加载后隐藏,可以有效减少用户的等待焦虑。本文将详细介绍如何使用 jQuery 实现这一功能。 ... [详细]
  • 本文介绍了如何在Linux系统中获取库源码,并在从源代码编译软件时收集所需的依赖项列表。 ... [详细]
  • LeetCode 125: 验证回文字符串 (Valid Palindrome)
    本题要求检查给定的字符串是否为回文。在判断过程中,仅考虑字母和数字字符,并且忽略大小写。例如,"A man, a plan, a canal: Panama" 是一个回文。 ... [详细]
  • 本文详细介绍了在Mac平台上安装和配置MySQL的步骤,包括下载安装包、卸载MySQL以及解决命令行中找不到mysql命令的问题。 ... [详细]
  • 本文详细探讨了Spring框架中遇到的NoSuchBeanDefinitionException异常,具体涉及com.thinkplatform.dao.UserLogDao Bean未定义的问题,并提供了相应的解决方案。 ... [详细]
  • Ubuntu 环境下配置 LAMP 服务器
    本文详细介绍了如何在 Ubuntu 系统上安装和配置 LAMP(Linux、Apache、MySQL 和 PHP)服务器。包括 Apache 的安装、PHP 的配置以及 MySQL 数据库的设置,确保读者能够顺利搭建完整的 Web 开发环境。 ... [详细]
  • 本文介绍了编程语言的基本分类,包括机器语言、汇编语言和高级语言的特点及其优缺点。随后详细讲解了Python解释器的安装与配置方法,并探讨了Python变量的定义、使用及内存管理机制。 ... [详细]
author-avatar
手机用户2502891227
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有