实验8 Oracle数据库备份与恢复1 实验目的(1)掌握Oracle数据库各种物理备份方法。
(2)掌握Oracle数据库各种物理恢复方法。
(3)掌握利用RMAN工具进行数据库的备份与恢复。
(4)掌握数据的导入与导出操作。
2 实验要求(1)对BOOKSALES数据库进行一次冷备份。
(2)对BOOKSALES数据库进行一次热备份。
(3)利用RMAN工具对BOOKSALES数据库的数据文件、表空间、控制文件、初始化参数文件、归档日志文件进行备份。
(4)利用热备份恢复数据库。
(5)利用RMAN备份恢复数据库。
(6)利用备份进行数据库的不完全恢复。
3 实验步骤(1)关闭BOOKSALES数据库,进行一次完全冷备份。
select file_name from dba_data_files;select member from v$logfile;select value from v$parameter where name='control_files';(2)启动数据库后,在数据库中创建一个名为cold表,并插入数据,以改变数据库的状态。
CREATE TABLE COLD(ID NUMBER PRIMARY KEY,NAME VARCHAR2(25));(3)利用数据库冷备份恢复BOOKSALES数据库到备份时刻的状态并查看恢复后是否存在cold表。
(4)将BOOKSALES数据库设置为归档模式。
1.1 shutdown immediate 正常关闭数据1.2 startup mount;将数据库启动到mount状态3)、关闭flash闪回数据库模式,如果不关闭的话,在后面关闭归档日志的时候就会出现讨厌的ora-38774错误。
alter database flashback off1.3 alter database archivelog;发出设置归档模式的命令1.4 alter database open;打开数据库1.5 再次正常关闭数据库,并备份所有的数据文件和控制文件1.6archive log list;在将数据库设置为归档模式后,可以执行此命令进行确认1.6.1 Database log mode 为Archive Mode说明当前的数据库为归档模式1.6.2 Automatic archival为Enable说明启动了自动归档。
(5)对BOOKSALES数据库进行一次热备份。
select tablespace_name,file_name from dba_data_files order by tablespace_name;alter tablespace users begin backup;alter tablespace users end backup;alter database backup controLfile to 'G:\APP\LENOVO\BOOKSALES\CONTROL1.BKP';alter database backup controlfile to trace;Alter system archive log current;Alter system switch logfile;(6)在数据库创建一个名为hot表,并插入数据库,以改变数据库的状态。
create table hot(id number primary key,name varchar2(25))2 tablespace users;insert into hot values(93,'panyifan');(7)假设保存hot表的数据文件损坏,利用热备份进行数据库恢复。
SQL> SHUTDOWN ABORTORACLE 例程已经关闭。
SQL> STARTUP MOUNTORACLE 例程已经启动。
SQL> ALTER DATABASE DATAFILE'G:\app\lenovo\BOOKSALES\USERS01.DBF'OFFLINE;SQL> ALTER DATABASE OPEN;SQL>RECOVER DATAFILE'G:\app\lenovo\BOOKSALES\users01.dbf';完成介质恢复。
SQL> alter database datafile'G:\app\lenovo\BOOKSALES\users01.dbf'online;(8)数据库恢复后,验证hot表的状态及其数据情况。
(9)利用数据库的热备份,进行基于时间的不完全恢复。
SQL> SHUTDOWN ABORTORACLE 例程已经关闭。
SQL> STARTUP MOUNTORACLE 例程已经启动。
recover database until time '2017-07-07';(10)为了使用RMAN工具备份与恢复BOOKSALES数据库,配置RMAN的自动通道分配。
connect target sys/liuqin@booksalesconfigure default device type to sbt;configure device type disk parallelism 2;configure device type disk parallelism 3;Configure channel 3 device type disk maxpiecesize=50m;(11)利用RMAN工具完全备份BOOKSALES数据库。
BACKUP DATABASE FORMAT 'G:\app\lenovo\product\11.2.0\dbhome_1\inventory\backup\%U.BKP';(12)利用RMAN工具备份BOOKSALES数据库的初始化参数文件和控制文件。
BACKUP SPFILE FORMAT 'G:\BACKUP\%U';RMAN> BACKUP CURRENT CONTROFILE FORMAT'G:\BACKUP\%U.CTL';(13)利用RMAN工具对USERS表空间、BOOKTB1表空间进行备份。
BACKUP TABLESPACE users,BOOKTB1 FORMAT 'D:\BACKUP\%U.BKP';(14)利用RMAN工具对BOOKSALES数据库的数据文件user01.dbf、user02.dbf 进行备份。
BACKUP DATAFILE 'G:\app\lenovo\BOOKSALES\USERS01.DBF'FORMAT 'G:\app\lenovo\BOOKSALES\%u';BACKUP DATAFILE 'G:\app\lenovo\BOOKSALES\USERS02.DBF'FORMAT 'G:\app\lenovo\BOOKSALES\%u';(15)利用RMAN工具备份BOOKSALES数据库形成的备份集,恢复数据库。
SHUT DOWN IMMEDIATE;STARTUP MOUNT;RESTORE DATABASE;RECOVER DATABASE;ALTER DATABASE OPEN;ALTER DATABASE OPEN RESETLOGS;(16)利用EXPDP工具导出BOOKSALES数据库的整个数据库。
create or replace directory dumpdir as 'D:\BACKUP';SQL> GRANT READ,WRITE ON DIRECTORY dumpdir TO human; SQL> grant exp_full_database,imp_full_database to human;expdp system/liuqin directory=dpum_dir DUMPFILE=expfull.dmp FULL=YES NOLOGFILE=YES(17)利用EXPDP工具导出BOOKSALES数据库的USERS表空间。
Expdp system/tiger DIRECTORY=DPUMP_DIR DUMPFILE=EXPFULL.DMP FULL=YES NOLOGFILE=YES(18)利用EXPDP工具导出BOOKSALES数据库的publishers表和books表。
EXPDP SYSTEM/LIUQIN DIRECTORY=DPUMP_DIR DUMPFILE=PUBLISHERS_BOOKS.DMPLOGFILE=PUBLISHERS_BOOKS.LOG TABLES=scott.emp,scott.dept PARALLEL=3(19)利用EXPDP工具导出BOOKSALES数据库中bs模式下所有数据库对象及数据。
expdp bs/liuqin directory=dpum_dir DUMPFILE=expfull.dmp FULL=YES NOLOGFILE=YES(20)删除BOOKSALES数据库中的orderitem表和order表,使用转储文件,利用IMPDP工具进行恢复。
Drop table orderitem;Drop table order;Impdp scott/liuqin DIRECTORY=DPUMP_DIR DUMPFILE=EMP_DEPT.DMP TABLES=DEPT,EMPNOLOGFILE=Y4 实验总结本次实验主要内容为“Oracle数据库备份与恢复”,因此在以后的数据库应用中起到很重要的作用。
但本次实验有一定的难度,尤其老师还未在课堂讲过的利用RMAN工具,EXPDP工具,IMPDP工具进行备份,恢复,和导入导出数据,代码能够理解,但是用cmd启动expdp和impdp却未能解决。
THANKS !!!致力为企业和个人提供合同协议,策划案计划书,学习课件等等打造全网一站式需求欢迎您的下载,资料仅供参考。