为啥要写这个呢,因为之前遇到个场景。操作系统为Solaris的,oracle11.2.0.4。

一个运维把一张关键表drop了。然后发现recyclebin是off的,然后。。然后好像只能从备份里面找了,没有逻辑备份,只有备份到虚拟磁带机的RMAN备份。好吧,问题也不大找个测试机基于时间点恢复,再expdp导入。可是没有Solaris的机器,整个数据库4T,跨平台恢复呢。。也要好长时间。于是想到了表空间恢复,但是出故障后,并没有及时把表空间offline,导致其他的表继续写,然后就尴尬了。后来找的专家用工具修复的。

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

想了想有个很low思路可行(请不要嘲笑本咸鱼),但可能局限性比较大。

1.先将除了A表(被drop的表)其他的表备份出来(expdp)或者移动到其他表空间。

2.用表空间恢复到指定时间点,找到了A表。

3.再将其他的表再导入表空间。

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

记录下表空间恢复步骤(其实我也是抄别人的哈哈哈)。

1.故障表空间offline,实例时open的

2.建立辅助实例恢复

全自动(自动建立辅助实例)

rman target /

RMAN> RECOVER TABLESPACE test01 UNTIL SCN=1002453  auxiliary destination '/home/oracle';

手动(需要建立辅助实例)

rman target  /  auxiliary sys/oracle@jssdup

run
{
set newname for tablespace test01 to '/home/oracle/data/%b';
set newname for datafile '/u01/app/oracle/oradata/orcl/system01.dbf' to '/home/oracle/data/system01.dbf';
set newname for datafile '/u01/app/oracle/oradata/orcl/sysaux01.dbf' to '/home/oracle/data/sysaux01.dbf';
set newname for datafile '/u01/app/oracle/oradata/orcl/undotbs01.dbf' to '/home/oracle/data/undotbs01.dbf';
set newname for datafile '/u01/app/oracle/oradata/orcl/users01.dbf' to '/home/oracle/data/users01.dbf';
allocate auxiliary channel c1 device type disk;
recover tablespace test01 until scn 1002453;
}

3.然后就OK了。

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

表空间时点恢复TSPITR原理及步骤

1.自包含检查,也就是检查是否存在依赖性。执行DBMS_TTS.TRANSPORT_SET_CHECK后,查看视图TRANSPORT_SET_VIOLATIONS,如果有记录被返回,则需要先解决依赖。

2.检查是否连接到一个用户管理的辅助实例,否则RMAN将创建一个辅助实例,启动并连接到辅助实例。

3.在目标数据库中将要被恢复的表空间置于脱机状态。

4.对辅助实例使用恢复目标时间之前的控制文件备份来还原控制文件。

5.从恢复集和辅助集中将数据文件还原到辅助实例。还原的数据文件可以存储在你指定的目录中或者是文件的原始目录中(对于恢复集文件)或者在辅助目录中(对于辅助集文件,如果你使用了有auxliary destination参数的recover tablespace命令)。

6.在辅助实例中将数据文件还原和恢复到指定的目标时间点。

7.使用resetlogs选项将辅助实例打开

8.将辅助实例上恢复集表空间置为只读模式

9.使用DataPump从辅助实例导出恢复集表空间产生一个传输表空间dump文件

10.关闭辅助实例

11.从目标实例删除恢复集表空间(即需要进行时点还原的表空间)

12.DataPump程序将使用传输表空间方式将dump文件导入到目标数据库

13.将导入到目标数据库的表空间置为读/写并立即离线

14.删除所有辅助集数据文件

原文:https://blog.csdn.net/leshami/article/details/70670220

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

其实我一直只想做到第8步,然后从辅助实例中expdp导出表A,但是好像一直没办法停下。。。有大佬有办法请告诉我,谢谢!

Oracle 表空间恢复的更多相关文章

  1. ORACLE表空间offline谈起,表空间备份恢复

    从ORACLE表空间offline谈起,表空间备份恢复将表空间置为offline,可能的原因包括维护.备份恢复等目的:表空间处于offline状态,那么Oracle不会允许任何对该表空间中对象的SQL ...

  2. ORACLE表空间管理维护

    1:表空间概念 在ORACLE数据库中,所有数据从逻辑结构上看都是存放在表空间当中,当然表空间下还有段.区.块等逻辑结构.从物理结构上看是放在数据文件中.一个表空间可由多个数据文件组成. 如下图所示, ...

  3. Oracle 表空间联机(online)与脱机(offline)

    数据库管理员可以在数据库处于开启(open)状态时令除 SYSTEM 表空间(tablespace)之外的任何表空间联机(online)(可访问)或脱机(offline)(不可访问).SYSTEM 表 ...

  4. Oracle表空间管理

    oracle表空间相关常用命令小结: 1.ALTER DATABASE SET DEFAULT BIGFILE TABLESPACE;              //修改表空间数据文件类型 2.ALT ...

  5. 【转】Oracle 表空间与数据文件

    --============================== --Oracle 表空间与数据文件 --============================== /* 一.概念 表空间:是一个或 ...

  6. oracle 表空间管理

    1.创建表空间 03:01:55 sys@ORADB11G> create tablespace TSPITR datafile '/u01/app/oracle/oradata/TSPITR0 ...

  7. 【基础】Oracle 表空间和数据文件

    多个表空间的优势:1.能够将数据字典与用户数据分离出来,避免由于字典对象和用户对象保存在同一个数据文件中而产生的I/O冲突2.能够将回退数据与用户数据分离出来,避免由于硬盘损坏而导致永久性的数据丢失3 ...

  8. interview:about Oracle表空间

    Oracle表空间 SQL Server数据库与Oracle数据库之间最大的区别要属表空间设计.Oracle数据库开创性地提出了表空间的设计理念,这为Oracle数据库的高性能做出了不可磨灭的贡献.可 ...

  9. ORACLE表空间

    在ORACLE数据库中,所有数据从逻辑结构上看都是存放在表空间当中,当然表空间下还有段.区.块等逻辑结构.从物理结构上看是放在数据文件中.一个表空间可由多个数据文件组成. 如下图所示,一个数据库由对应 ...

随机推荐

  1. 2018-2019-1 20189208《Linux内核原理与分析》第九周作业

    活动 main函数编译有问题,div 函数和系统中某个函数重名,浮点输出有问题,scanf也有问题 修改如下 scanf_s("%d %d", &a, &b); p ...

  2. JQuery Advanced

    1.Jquery Utility <1> Type & Function & setTimeOut <!DOCTYPE html> <html lang= ...

  3. 记录一下,PC端vue开发常用框架,已经用过elementUI和iview 接下来尝试另一个Muse-UI 喜欢它的点击效果

    官网地址: https://muse-ui.org/#/zh-CN/installation

  4. 【java】Java组件概览(1)

    如上图所示,Oracle的Java SE8有两个产品:JDK和JRE.其中,JRE的内容包括图中①~⑤,它是JDK的子集. ⑥中的红色部分与JRE有重合. [参考] 1.https://docs.or ...

  5. PHP源码安装后设置别名

    PHP源码安装后测试是否能正常运行 每次在php目录./bin./php调用php很不方便,可以设置别名(方法一) vi ~/.bash_profile     (修改根目录下这个文件) 设置完成后还 ...

  6. C++ const用法

    C++ const 允许指定一个语义约束,编译器会强制实施这个约束,允许程序员告诉编译器某值是保持不变的.如果在编程中确实有某个值保持不变,就应该明确使用const,这样可以获得编译器的帮助. 1.c ...

  7. java中的BigDecimal和String的相互转换,int和String的类型转换,Integer类和String相互转换

    一: /*由数字字符串构造BigDecimal的方法 *设置BigDecimal的小数位数的方法 */ 注:BigDecimal在数据库中存的是number类型. import java.math.B ...

  8. Ubuntu系统查看显卡型号和NVIDIA驱动版本

    查看GPU型号 lspci | grep -i nvidia 查看NVIDIA驱动版本 sudo dpkg --list | grep nvidia-*

  9. java 安装以及配置

    1.下载 JDK 下载地址:https://www.oracle.com/technetwork/java/javase/downloads/index-jsp-138363.html 2.环境变量配 ...

  10. BZOJ4827 [Hnoi2017]礼物 多项式 FFT

    原文链接http://www.cnblogs.com/zhouzhendong/p/8823962.html 题目传送门 - BZOJ4827 题意 有两个长为$n$的序列$x$和$y$,序列$x,y ...