手工备份恢复oracle数据库:

  虽然已经有了rman工具

  但是手工恢复oracle能够让你对oracle数据库有更加深入的了解

数据库一致性开机条件:
  数据文件 scn,控制文件 scn,redo scn一致

控制文件记录:
  数据文件应该到达的scn
  当前redo
  数据的物理结构信息
  归档信息

  

前提条件:

  归档日志开启

  数据文件有备份

  控制文件有备份

备份数据:

  数据文件备份:

    数据文件进入备份模式:

    select 'alter tablespace '|| tablespace_name||' begin backup;' from dba_tablespaces where tablespace_name not like '%TEMP%';

    

    确认进入备份状态:

    

    再操作系统执行物理拷贝命令:

     cp *.dbf /home/oracle/sg_backup_dbf/

    拷贝完成,退出备份模式:

    

    数据文件备份完成!!!

    备份完成切换几次归档(多切换几次)

    alter system switch logfile;

  控制文件备份:

    备份成二进制的形式:

      SQL>alter database backup controlfile to '/home/oracle/backup_ctl/PROD4_CTL_20170703';

    备份成逻辑文件:

      SQL> alter database backup controlfile to trace as '/home/oracle/backup_ctl/prod4.ctl';

     

一、表空间数据文件删除恢复:

重启数据报错:

  

根据提示查看数据文件已经不存在(被删除)

通过拷贝先前备份数据文件进行恢复:

  cp /home/oracle/sg_backup_dbf/* .

查看scn号:(不一致状态)  

  

通过执行recover database进行数据恢复()

  

启动数据库:

  SQL> alter database open;

#恢复完成!

二、控制文件被删除:

重启数据库:

  

通过老版本数据文件恢复:

  cp /home/oracle/backup_ctl/PROD4_CTL_20170703 ./control01.ctl

  cp /home/oracle/backup_ctl/PROD4_CTL_20170703 ./control02.ctl

再次重启:

  

执行恢复:

  SQL> recover database using backup controlfile until cancel;

    #auto 模式

    报错:

      (旧的控制文件并不知道redo的情况)  

      

再次执行恢复:

  SQL> recover database using backup controlfile until cancel;

    #Specify log: {<RET>=suggested | filename | AUTO | CANCEL}

    #/u01/app/oracle/oradata/PROD4/PROD4/redo01.log      #使用指定的redo文件恢复(手动输入这行)

开机:

  SQL> altr database open resetlogs;

恢复完成!

控制文件损坏进行恢复后需要进行一次全备

  使用altr database open resetlogs; 开机时,重新初始化了redolog,

  archive log,以前的数据文件的备份全部失效

删除无用archive log

三、当前redo损坏

重启数据库无法开机

恢复:

   删除数据文件

   使用旧备份恢复数据文件

    恢复和前面提到的类似:

    恢复命令:

      recover database using backup controlfile until cancel;

        #auto
     recover database using backup controlfile until cancel;
        #cancel

   删除控制文件

   关闭数据库

   使用备份的逻辑控制文件恢复控制文件(找出类似如下部分,直接执行)

  (恢复控制文件时需要数据文件,但是使用现在的数据文件是不行的,这就是前面先删除数据文件再恢复的原因)

      

执行开机:

  alter database open resetlogs;

全备
删除无用archive log

总结:

  一致性开机的原理

    scn号

  开机的步骤

  开机的所需文件

  

手工备份恢复oracle数据库的更多相关文章

  1. Navicat备份远程Oracle数据库到本地

    公司的数据库是本地的,我只能在公司连,回家就不能跑项目了,一跑就报SQLException,所以希望可以把数据库复制到我的本地来. 因为一直在用Navicat操作数据库,这里就分享一下用Navicat ...

  2. [转]PLSQL Developer备份恢复oracle数据

    本文转自:http://www.cnblogs.com/iampkm/archive/2013/06/09/3128273.html 使用PL sql提供的功能可以快速的备份恢复oracle数据. 1 ...

  3. PLSQL Developer备份恢复oracle数据

    使用PL sql提供的功能可以快速的备份恢复oracle数据. 1  导出存储过程,触发器,序列等所有用户对象.(备份) 在PL/SQL Developer的菜单Tools(工具) => Exp ...

  4. PL/SQL远程备份和恢复Oracle数据库

    (转自:http://blog.csdn.net/huchunfu/article/details/25165901) 在客户端远程备份的文件保存在数据库所在主机上,不会直接拷贝到客户端.—————— ...

  5. 详解:数据库名、实例名、ORACLE_SID、数据库域名、全局数据库名、服务名及手工脚本创建oracle数据库

    数据库名.实例名.数据库域名.全局数据库名.服务名 , 这是几个令很多初学者容易混淆的概念.相信很多初学者都与我一样被标题上这些个概念搞得一头雾水.我们现在就来把它们弄个明白. 一.数据库名 什么是数 ...

  6. 恢复oracle数据库误删除数据的方法汇总

    学习数据库时,我们只是以学习的态度,考虑如何使用数据库命令语句,并未想过工作中,如果误操作一下,都可能导致无可挽回的损失.当我在工作中真正遇到这些问题时,我开始寻找答案.今天主要以oracle数据库为 ...

  7. 如何将备份的oracle数据库还原到指定用户下。

    上一文章 oracle11g数据库--创建表空间,创建用户,用户授权并指定表空间.我们已经建好了指定的新用户pdmis. 接下来我们需要将备份好的数据库,还原至新用户pdmis下. 想要还原,我们需要 ...

  8. 系统重装后恢复Oracle数据库

    这周装系统的固态盘坏了,固态硬盘用到坏也是第一次碰到....只能新买个硬盘重装系统了.到了Oracle数据库恢复那一步了,其实很简单.只要没把数据库安装路径放在系统盘就行.*^____^* 先找到重装 ...

  9. CentOS 上面 恢复 Oracle 数据库实例的简单操作流程

    1. 当获取了数据库的备份可以进行 oracle数据库的备份恢复操作 linux上面要复杂一些. 这里面简单描述一下. 2. 远程连接 linux 主要工具可以选择 xshell 如图示: 3. 建议 ...

随机推荐

  1. Java基础——StringBuffer和StringBuilder

    本节讲述2个字符串容器的区别 StringBuffer和StringBuilder区别: 1.相同点 两者都是容器(可变的字符序列),都可以对字符串进行基本的“增删改查”操作. 2.不同点 Strin ...

  2. P3387 【模板】缩点 && P3388 【模板】割点(割顶)

    Tarjan算法 应用: 有向图的强连通分量 无向图割点和桥 双连通分量 接下来主要谈论前面两者的应用(主要是第三种还没学会) 算法简要介绍 我们需要先理解一下知识:搜索树 有向图的搜索树的4种边,如 ...

  3. BZOJ 4026 dC Loves Number Theory (主席树+数论+欧拉函数)

    题目大意:给你一个序列,求出指定区间的(l<=i<=r) mod 1000777 的值 还复习了欧拉函数以及线性筛逆元 考虑欧拉函数的的性质,(l<=i<=r),等价于 (p[ ...

  4. 小白都能看懂的Linux系统下安装配置Zabbix

    实验环境: 操作系统:Centos 7.6 服务器ip:192.168.10.100 运行用户:root 网络环境:Internet Zabbix是一个基于web界面的提供分布式系统监控及网络功能的企 ...

  5. java源码之TreeSet

    1,TreeSet介绍 1)TreeSet 是一个有序的集合,它的作用是提供有序的Set集合.2)TreeSet 继承于AbstractSet,所以它是一个Set集合,具有Set的属性和方法.3)Tr ...

  6. vim 跳转指定行

    在编辑模式下输入 ngg 或者 nG n为指定的行数(如25) 25gg或者25G 跳转到第25行. 在命令模式下输入行号n : n 如果想打开文件即跳转 vim +n FileName 查看当然光标 ...

  7. HDU 4165

    一块药看成括号配对就行了.很明显的直接求卡特兰数. 今晚看了HDU 3240的题,有一点思路,但无情的TLE.想不到什么好方法了,看了别人的解答,哇...简直是天才的做法啊....留到星期六自己思考一 ...

  8. mysql数据库连接工具类C3P0

    package com.dl.network_flow.db; import java.sql.Connection; import java.sql.PreparedStatement; impor ...

  9. 构建自己的AngularJS - 作用域和Digest(三)

    作用域 第一章 作用域和Digest(三) $eval - 在当前作用域的上下文中运行代码 Angular有多种方式让你在当前作用域的上下文中运行代码.最简单的是$eval.传入一个函数当做其參数.然 ...

  10. 三种SVM的对偶问题

    一.SVM原问题及要变成对偶问题的解决办法 对于SVM的,我们知道其终于目的是求取一分类超平面,然后将新的数据带入这一分类超平面的方程中,推断输出结果的符号,从而推断新的数据的正负. 而求解svm分类 ...