@H_502_2@关于备份之言已经发布了一章rman工具的使用 今天九妹带你玩转数据泵 -----
一.数据泵
数据泵实现逻辑备份@H_502_2@
逻辑备份是创建数据库对象的逻辑副本,并存入一个二进制转储文件的过程。从本质上说,逻辑备份与恢复实际就是对数据库实施数据的导入和导出。@H_502_2@
@H_502_2@
导出:@H_502_2@
导出即数据库的逻辑备份,实质是读取一个数据库集并将这个数据集写入一个文件(扩展名通常是@H_502_2@dmp),这些记录的导出与物理位置无关。@H_502_2@@H_502_2@
导入:@H_502_2@
导入及数据库的逻辑恢复,实质是读取被导出的二进制转储文件并将其恢复到数据库。@H_502_2@
@H_502_2@
1、使用数据泵技术导入@H_502_2@/导出@H_502_2@@H_502_2@
数据泵(@H_502_2@data pump)是一种在数据库之间或在数据库与操作系统之前高速传输的技术。数据泵工具运行在服务器上,数据库管理员需要指定数据库目录来保存转储的数据。@H_502_2@@H_502_2@
基于命令行的数据泵导出步骤如下@H_502_2@
1)连接@H_502_2@oracle数据库@H_502_2@@H_502_2@
在连接数据库之前 首先创建一个操作目录存放的位置
mkdir -p /opt/backup @H_502_2@
chown -R oracle:oinstall /opt/backup@H_502_2@
alter user scott account unlock@H_502_2@
设置密码为scott:alter user scott identified by pwd123@H_502_2@
2)创建操作目录及授予用户对目录的权限
3)
5)导出@H_502_2@scott用户下的表@H_502_2@@H_502_2@
使用@H_502_2@expdp命令导入数据(可以按照表导出,按照用户模式导出,按照表空间导出和全库导出),使用@H_502_2@impdp@H_502_2@命令导入数据(可以按照表导入,按照用户模式导入,按照表空间导入和全库导入)。@H_502_2@@H_502_2@
expdf scott/pwd123 direcotry=dump_dir dumpfile=scott.dmp tables=emp,dept@H_502_2@
6)已经备分成 公
测试删除emp表
sqlplus scott/pwd123
drop table emp;
7)导入emp表
8)select * from scott.emp
查看是否恢复回来
二.使用闪回技术@H_502_2@
为了使数据库能够从任何逻辑误操作中迅速恢复,@H_502_2@oracle退出了闪回技术。@H_502_2@采用该技术,可以对行级和事务级的数据变化进行恢复,减少了数据恢复的时间,而且操作简单,通过@H_502_2@sql@H_502_2@语句就可以实现数据的恢复,大大提高了数据库恢复的效率。@H_502_2@@H_502_2@闪回技术是数据库恢复技术历史上一次重大的进步,从根本上改变了数据恢复。@H_502_2@@H_502_2@
1)闪回查询(flashback query):查询过去某个时间点或某个SCN@H_502_2@(system change number@H_502_2@,系统更改号)值时表中的数据信息。@H_502_2@
2)闪回版本查询(flashback version query):查询过去某个时间段或某个SCN@H_502_2@段内表中数据的变化情况。@H_502_2@
3)闪回事务查询(flashback transaction query):查看某个事务或所有事务在过去一段时间对数据进行的修改。@H_502_2@
4)闪回数据库(flashback database):将数据库恢复到过去某个时间点或某个SCN@H_502_2@值时的状态。@H_502_2@
5)闪回删除(flashback drop):将已经删除的表及相关联的对象恢复到删除前的状态。@H_502_2@
6)闪回表(flashback table):将表恢复到过去的某个时间点或某个SCN@H_502_2@值时的状态。@H_502_2@
SCN:@H_502_2@scn@H_502_2@是当@H_502_2@Oracle@H_502_2@数据库更新后,有@H_502_2@dbms@H_502_2@自动维护而累积递增的一个数字,可以通过查询数据字典@H_502_2@V$DATABASE@H_502_2@中的@H_502_2@CURRENT_SCN@H_502_2@获得当前的@H_502_2@SCN@H_502_2@号。@H_502_2@@H_502_2@
@H_502_2@
注意:@H_502_2@
闪回数据库是基于闪回恢复区(@H_502_2@Flash Recovery Area)特性实现的,如果要使用闪回数据库技术,还需要启用闪回恢复区@H_502_2@@H_502_2@
闪回删除是基于回收站(@H_502_2@Recycle Bin)特性实现的,如果要使用闪回删除技术,还需要启用回收站@H_502_2@@H_502_2@
闪回查询、闪回版本查询、闪回事务查询以及闪回表主要是基于撤销表空间中的回滚信息实现的@H_502_2@
@H_502_2@
Oracle推荐指定一个闪回恢复区(@H_502_2@flash recovery area@H_502_2@)作为存放备份与恢复相关文件的默认位置,这样@H_502_2@oracle@H_502_2@就可以实现自动的基于磁盘的备份与恢复(@H_502_2@automatic disk-based backup and recovery@H_502_2@)。那么,什么是闪回恢复区?简单地说,闪回恢复区是一块用以存储恢复相关的文件的存储空间,允许用户集中存储所有恢复相关的文件。如下集中文件可以放到闪回恢复区中。@H_502_2@@H_502_2@
闪回日志@H_502_2@
控制文件和@H_502_2@SPFILE自动备份@H_502_2@@H_502_2@
@H_502_2@
闪回恢复区提供了一个集中化的存储区域,很大程度上减少了管理开销,这是其最主要的优点,另外,与@H_502_2@RMAN结合使用可以进行快速恢复。@H_502_2@@H_502_2@
@H_502_2@
闪回恢复区主要通过以下@H_502_2@3个初始化参数来设置和管理。@H_502_2@@H_502_2@
Db_recovery_file_dest:指定闪回恢复区的位置@H_502_2@@H_502_2@
Db_recovery_file_dest_size:指定闪回恢复区的可用空间大小@H_502_2@@H_502_2@
Db_flashback_retention_target:该参数用来控制闪回日志中数据保留的时间,或者说,希望闪回数据库能够恢复到的最早的时间点。单位为@H_502_2@MIN@H_502_2@,默认为@H_502_2@1440min@H_502_2@,也就是一天。当然,实际上可退回的时间还取决于闪回恢复区的大小,因为里面保存了回退所需要的闪回日志,所以这个参数要和@H_502_2@db_recovery_file_dest_size@H_502_2@配合修改。@H_502_2@@H_502_2@
如果要撤销闪回恢复区,把初始化参数@H_502_2@DB_RECOVERY_FILE_DEST的值清空即可。@H_502_2@@H_502_2@
@H_502_2@
注意:@H_502_2@db_recovery_file_dest_size只有在@H_502_2@db_recovery_file_dest@H_502_2@清空之后才可以清空。@H_502_2@@H_502_2@
设置可闪回恢复区之后,要启用闪回数据库的功能,还需要进一步配置。数据库必须已经处于归档模式,再设置闪回数据库。@H_502_2@
启用归档模式(闪回数据库只能处于归档模式)@H_502_2@
@H_502_2@
shutdown immediate @H_502_2@
startup mont@H_502_2@
3)设置归档模式@H_502_2@
alter database archivelog@H_502_2@
archive log list @H_502_2@
3.设置闪回@H_502_2@
查看是否设置闪回@H_502_2@
建立闪回区@H_502_2@
@H_502_2@
设置闪回数据库的数据保留周期为一天以@H_502_2@min为单位@H_502_2@@H_502_2@
@H_502_2@
启用闪回日志
shutdown immediate
查询是否已经启用闪回