环境:windows7、Oracle11g

一、脱机备份
脱机备份是指在数据库关闭情况下的数据备份,也称为冷备份。

在书上学到的备份步骤:
1、记录所要备份数据库文件所在的操作系统路径;
2、关闭数据库,不要使用shutdown abort这种关闭方式;
3、拷贝数据库文件到备份目录中;
4、重启数据库,完成备份。

了解到这些步骤后,做了一个备份测试,要备份的数据库为testdb。

1、记录所要备份数据库文件所在的操作系统路径
   
(1)查看数据文件的路径(用管理员账户连接)
备注:可以在sqlplus命令行或者plsql执行下面sql语句

select file_name,tablespace_name from dba_data_files;

D:\APP\LC\ORADATA\TESTDB\USERS01.DBF     USERS
D:\APP\LC\ORADATA\TESTDB\UNDOTBS01.DBF   UNDOTBS1
D:\APP\LC\ORADATA\TESTDB\SYSAUX01.DBF    SYSAUX
D:\APP\LC\ORADATA\TESTDB\SYSTEM01.DBF    SYSTEM

(2)查看控制文件的路径
select name from v$controlfile;

D:\APP\LC\ORADATA\TESTDB\CONTROL01.CTL
D:\APP\LC\FLASH_RECOVERY_AREA\TESTDB\CONTROL02.CTL

(3)查看重做日志文件的路径
select member from v$logfile;

D:\APP\LC\ORADATA\TESTDB\REDO03.LOG
D:\APP\LC\ORADATA\TESTDB\REDO02.LOG
D:\APP\LC\ORADATA\TESTDB\REDO01.LOG

2、关闭数据库

SQL> conn system/Oracle123456@testdb as sysdba
已连接。
SQL> shutdown immediate
数据库已经关闭。
已经卸载数据库。
ORACLE 例程已经关闭。

3、拷贝数据库文件到备份目录中;
如果在sqlplus下可以使用host copy拷贝,也可以直接选择文件拷贝,把第1步的所有文件拷贝到D:\dbbackup中。

4、启动数据库。

SQL> startup
ORACLE 例程已经启动。
......

二、数据库恢复
为了模拟数据库恢复,在DBCA工具中把testdb删除掉,删除成功后,执行下面恢复步骤。
1、把D:\dbbackup中的文件拷贝到原来的D:\APP\LC\ORADATA\TESTDB等目录下。
2、新建一个实例
  用管理员权限,在cmd窗口执行下面语句,其中testdb名称要与备份的名字一样
  oradim -new -sid testdb
3、查看oracle服务和监听是否启动,如果没启动,则到控制面板的服务或cmd下运行命令启动。
   启动服务 net start OracleServicetestdb
   启动监听 lsnrctl start
4、启动数据库
   cmd命令窗口中
   输入   set oracle_sid=testdb回车
   再输入 sqlplus  /nolog 回车
   再输入 conn / as sysdba 回车
   再输入startup 回车

这时却出现了错误:
ORA-01078: failure in processing system parameters
LRM-00109: could not open parameter file 'D:/app/LC/product/11.2.0/dbhome_1/database/inittestdb.ora'

检查了这个路径,没有inittestdb.ora这个文件。

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

网上搜索了下,解决方法基本和下面大同小异:

解决方法:将$ORACLE_BASE/admin/数据库名称/pfile目录下的init.ora.012009233838形式的文件copy 到$ORACLE_HOME/database 目录下
initoracle.ora即可。(注:initoracle.ora中的oracle为你的实例名 ORACLE_SID
------------------------------------------------------
在电脑找了下,在D:\app\LC\admin\orcl\pfile目录下有一个init.ora.9182016154717文件,把它复制到
D:/app/LC/product/11.2.0/dbhome_1/database目录下,把里面内容的所有“orcl”改为“testdb”,保存为inittestdb.ora。
在D:\app\LC\admin目录下建立testdb及它的子目录pfile。
这时候再回到cmd命令行窗口执行startup,终于成功启动数据库了。

这时候用plsql登录却提示ORA-12154: TNS: 无法解析指定的连接标识符。
解决方法:
打开 D:\app\LC\product\11.2.0\dbhome_1\NETWORK\ADMIN\tnsnames.ora,模仿里面的ORCL代码,手动添加下面语句
TESTDB =
  (DESCRIPTION =
    (ADDRESS = (PROTOCOL = TCP)(HOST = localhost)(PORT = 1521))
    (CONNECT_DATA =
      (SERVER = DEDICATED)
      (SERVICE_NAME = testdb)
    )
  )

三、总结
通过上面例子,知道除了备份数据文件、控制文件、重做日志文件,还要备份参数文件。
于是重新建立一个数据库tdb,这次备份除了数据文件、控制文件、重做日志文件,还备份了
(1)D:\app\LC\product\11.2.0\dbhome_1\database目录下的3个文件:hc_tdb.dat、PWDtdb.ora、SPFILETDB.ORA
(2)D:\app\LC\admin\tdb整个目录,里面有adump、dpdump、pfile共3个目录,其中pfile下面有个init.ora.919201613321文件。
(3)D:\app\LC\product\11.2.0\dbhome_1\NETWORK\ADMIN\tnsnames.ora

恢复的时候把数据文件、控制文件、重做日志文件、SPFILETDB.ORA、tnsnames.ora内容还原。
终于成功恢复数据库。
hc_tdb.dat、PWDtdb.ora、D:\app\LC\admin\tdb目录似乎恢复没用到,但最好也是还原下。

附,恢复时候执行的命令行:

C:\Windows\system32>oradim -new -sid tdb
实例已创建。
C:\Windows\system32>set oracle_sid=tdb
C:\Windows\system32>sqlplus /nolog
SQL*Plus: Release 11.2.0.1.0 Production on 星期三 10月 19 15:25:45 2016
Copyright (c) 1982, 2010, Oracle.  All rights reserved.
SQL> conn /as sysdba
已连接到空闲例程。
SQL> startup
ORACLE 例程已经启动。
Total System Global Area 1686925312 bytes
Fixed Size                  2176368 bytes
Variable Size             989858448 bytes
Database Buffers          687865856 bytes
Redo Buffers                7024640 bytes
数据库装载完毕。
数据库已经打开。
SQL>

测试oracle数据库的脱机备份和恢复的更多相关文章

  1. ORACLE数据库不同故障下的恢复总结

    ORACLE数据库不同故障下的恢复总结1. 非归档模式下丢失或损坏的文件--1.1 数据文件--启动数据库的状态到MOUNT--恢复方法:通过之前创建的数据库完整备份,修复整个数据库,不过备份之后发生 ...

  2. Windows环境下Oracle数据库的自动备份脚本

    批处理文件(.bat) @echo off echo ================================================ echo  Windows环境下Oracle数据 ...

  3. Navicat工具Oracle数据库复制 or 备用、恢复功能(评论都在谈论需要教)

    GXPT它是一个分布式系统,该系统包括一个临时许可系统.基本系统.教学评价体系.考试系统,每个系统都有自己的oracle数据库.统,而评教系统的正常须要借助于权限系统和基础系统,详细的业务这里就不多解 ...

  4. Oracle数据库的自动备份脚本

    @echo off echo ================================================ echo Windows环境下Oracle数据库的自动备份脚本 echo ...

  5. Windows环境下Oracle数据库的自动备份脚本自动删除30天前的备份

    @echo off echo ================================================ echo Windows环境下Oracle数据库的自动备份脚本 echo ...

  6. 数据库通过sql备份脚本恢复时,报错误The user specified as a definer ('root'@'%') does not exist

    数据库通过sql备份脚本恢复时,报错误The user specified as a definer ('root'@'%') does not exist 当出现这个错误,意思是某个数据库对象的定义 ...

  7. Oracle数据库表的备份和数据表的删除操作

    --Oracle数据库中的表备份: --备份语句:在备份之后就可以将这张表的所有数据源删除了,但是之后有人对这张表的数据进行操作,但是在操作完成之后要记得将数据表恢复 CREATE TABLE DZH ...

  8. MySQL数据库的数据备份和恢复(导入和导出)命令操作语法【转】

    不管是Oracle数据库还是SQL Server数据库,每个数据库都有自己的一套数据备份和恢复的方法,MySQL数据库也不例外.MySQL数据库备份和恢复用到了两个命令,分别是“mysqldump”和 ...

  9. Windows系统下oracle数据库每天定时备份

    第一步:建立备份脚本oraclebackup.bat 首先建立一个备份bat文件,在D盘下新建备份目录oraclebackup,将oracle安装目录下的EXP.EXE复制到此目录下,再新建一个文本文 ...

随机推荐

  1. .NET Core Analysis

    .NET Core 1.0.1 Module Component .NET Core MongoDB MongoDB.Driver There has a nuget package availabl ...

  2. (转)CMOS Sensor的调试经验分享

    CMOS Sensor的调试经验分享 我这里要介绍的就是CMOS摄像头的一些调试经验. 首先,要认识CMOS摄像头的结构.我们通常拿到的是集成封装好的模组,一般由三个部分组成:镜头.感应器和图像信号处 ...

  3. asp.net mvc 5 web api 关于Requested resource does not support options 问题

    1.用visual studio 2015 建立一个 web api 应用程序.记住这是一个 web api 应用. 2.新建一个web api . 3.用C#访问,代码如下:[没有问题,返回正确] ...

  4. sprint3个人总结

    转眼间,这个学期又过去了,真的是忙碌的一个学期,却是有点充实,特别是我们的软件工程这门课程,我们这次做的是公众号开发功能,说实话,当初对这个项目有兴趣是因为自己也在弄自己一个300多人的公众号,对于这 ...

  5. Redis不同类型方法整合

    1     对value操作的命令 exists(key):确认一个key是否存在 del(key):删除一个key type(key):返回值的类型 keys(pattern):返回满足给定patt ...

  6. linux通过ntp设置系统时间

    1.查看本机时间 date 2.安装ntp并且设置开机启动 sudo yum -y install ntp chkconfig ntp on 3.立即更新系统时间 sudo ntpdate time. ...

  7. html a标签包含a标签,浏览器的行为处理

    a标签包含a标签 浏览器可能是为了避免a的转跳重复,所以禁止了a标签包含a标签,如何你的代码中有a标签包含a标签,那么浏览器将会重新编码外层a标签,取外层a标签与内层a标签的差集,加上外层a标签,并把 ...

  8. Android中top命令字段含义

    PID       PR     CPU%      S       #THR           VSS        RSS       PCY           UID      Name 1 ...

  9. Caffe + Ubuntu 14.04 64bit + 无CUDA(linux下安装caffe(无cuda)以及python接口)

    安装Caffe指导书 环境: Linux 64位 显卡为Intel + AMD,非英伟达显卡 无GPU 一. 安装准备工作 1. 以管理员身份登录 在左上角点击图标,搜索terminal(即终端),以 ...

  10. Hibernate 基础配置及常用功能(二)

    本章主要是描述几种经典映射关系,顺带比较Hibernate4.x和Hibernate5.x之间的区别. 一.建立测试工程目录 有关实体类之间的相互映射关系,Hibernate官方文档其实描述的非常详细 ...