文档详情

(Oracle热备份和冷备份.doc

发布:2017-01-22约8.9千字共13页下载文档
文本预览下载声明
Oracle 热备份 热备份较冷备份的主要区别就是不会丢失在备份后更新的数据 下面为SQL脚本: CREATE TABLE TEST ( T_ID NUMBER, T_VALUE VARCHAR2(30) ); / INSERT INTO TEST VALUES(100,WANG); INSERT INTO TEST VALUES(200,DONG); COMMIT; 1.SHUTDOWN IMMEDIATE;//关闭数据库 2.STARTUP MOUNT//启动数据实例,加载数据库 注:STARTUP NOMOUNT//启动数据实例 STARTUP MOUNT//启动数据实例,加载数据库 STARTUP //启动数据实例,加载数据库并打开数据库 3.ALTER DATABASE ARCHIVELOG;//设置数据库日志为存档模式 4.ALTER SYSTEM SET LOG_ARCHIVE_START=TRUE SCOPE=SPFILE;//重启数据库 5.ALTER DATABASE OPEN;//打开数据库 6.ALTER TABLESPACE USERS BEGIN BACKUP;//将数据库设置备份模式 7.HOST COPY D:\oracle\oradata\orcl\*.dbf D:\BAK\ //拷贝数据文件至备份文件中 8.ALTER TABLESPACE USERS END BACKUP;//结束备份状态 9.ALTER SYSTEM SWITCH LOGFILE;//切换日志,使当前日志归档 --------至此,热备份已经完成,备份文件保存在D:\BAK\目录下-------- 此时再插入数据, INSERT INTO TEST VALUES(300,XIN); COMMIT; 以下是故障重现 1.SHUTDOWN IMMEDIATE 2.STARTUP MOUNT 3.HOST DEL D:\oracle\oradata\orcl\USER01.dbf //故意删除一个数据文件,制造故障 4.SHUTDOWN IMMEDIATE 5.STARTUP //此时会警告,无法找到指定的文件DATA FILE 4,即是刚才删掉的数据文件,DATA FILE 4只是个代号,也有可能是DATA FILE 1,DATA FILE 2,等等 6.ALTER DATABASE DATAFILE 4 OFFLINE DROP;//让这个出故障的文件暂时先脱机 7.ALTER DATABASE OPEN;//打开数据库 8.HOST COPY D:\BAK\ HOST COPY D:\oracle\oradata\orcl\*.dbf//将前面备份的文件拷贝到系统目录中 9.RECOVER DATAFILE 4;//这一步,偶尔会出错,无法正确执行,而且无法正常关闭数据库,请如此这般操作,SHUTDOWN ABORT; STARTUP; 10.ALTER DATABASE DATAFILE 4 ONLINE; 11.SELECT * FROM TEST; T_ID T_VALUE ----------------------- 100 WANG 200 DONG 300 XIN 发现,备份之后又更新的数据没有丢失! Oracle 冷备份 停止所有的oracle服务,复制Oracle目录下的oradata文件夹下的数据库名整个目录复制备份。这样冷备份就完成了,当然也可以像网上所说的: 示例一、windows环境下的冷备份与恢复 在本例中,数据库实例名wh,所有数据文件、所有控制文件和所有联机REDO LOG 文件都在文件夹D:\oracle\ora92\wh中,备份恢复的操作如下: 1、 进入 sql*plus,以sysdba的身份登录数据库 SQLsys/oracle@wh as sysdba 2、 关闭数据库SQLshutdown immediate 3、 拷贝D:\oracle\ora92\wh到目标备份目录E:\bacakupora\wh 数据库冷备份完成。下面对数据库中的内容进行更改: 4、启动数据库 SQLstartup 5、删除数据 SQLdelete from wh.test (删除某个用户的表) 此时进行数据库恢复。 6、SQLshutdown immediate; 7、拷贝目标备份目录E:\bacakupora\wh到D:\oracle\ora92\wh 数据库恢复完毕。通过查询可以发现数据库恢复到进行备份时刻的状态,备份后所进行的所有操作无效。 今天网上找了很多恢复的都不管用,结果今天下午搞了一个下午,试了很多方法,终于可以了,以下我是总结的方法: 1.首先要注意恢复
显示全部
相似文档