Oracle基础 数据库备份和恢复
一、为什么需要数据备份
造成数据丢失的主要原因:
1、介质故障。
2、用户的错误操作。
3、服务器的彻底崩溃。
4、计算机病毒。
5、不可预料的因素。
Oracle中故障类型分为以下4种。
1、语句故障:
执行SQL语句过程发生的逻辑故障可导致语句故障。如果用户编写的SQL语句无效,就会发生语句故障。Oracle可自我修复语句故障,撤销语句产生的而印象,并将控制权交给应用程序。
2、用户进程故障
当用户程序出错而无法访问Oracle数据库时,就会发生用户进程故障。用户进程故障只会导致当前用户无法操作数据库,但不会印象其他用户进程,当用户进程出现故障时,进程监控程序(PMON)会自动执行进程恢复。
3、实例故障
当Oracle 数据库实例由于硬件或软件问题而无法继续运行时,就会发生实例故障。硬件问题包括意外断电,而然间问题可能是服务器操作系统崩溃。如果发现实例故障,Oracle会自动完成实例修复。实例修复将数据库恢复到与故障之前的事务一致状态,Oracle会自动回滚未提交的数据。
4、介质故障
介质故障是当一个数据库文件或者磁盘不能读或者不能写时出现的故障。
二、备份
备份就是把创建一个数据库副本到磁盘。从不同角度分类如下:
1、从物理角度与逻辑角度分类:
(1)物理备份:对数据库操作系统的物理文件(如数据文件、控制文件和日志文件等)的备份。物理备份又可分为脱机备份(冷备份)和联机备份(热备份),前者是在关闭数据库的时候进行的,后者对运行在归档日志方式的数据库进行备份。
(2)逻辑备份:对数据库逻辑组件(如表和存储过程等数据对象)的备份。
2、从数据库的备份策略角度分类:
(1)完全备份:每次对数据进行完整备份。
(2)增量备份:值有那些在上次完全备份或者增量备份后备修改的文件才会被备份。优点是备份数据量小,需要的时间短,缺点是恢复的时候需要依赖之前的备份记录,出问题的风险较大。例如:如果在星期一进行完全备份,在星期二至星期五进行增量备份。如果星期五数据被破坏了,则数据恢复需要星期一的完全备份和从星期二至星期五的所有增量备份。
(3)差异备份:备份那些从上次完全备份之后被修改过得文件。因此从差异备份中恢复数据的时间长短,因此只需要两份数据(最后一次完全备份和最后一次差异备份),缺点是每次备份的时间较长。例如:如果在星期一进行完全备份,在星期二到星期五进行了差异备份,如果星期五数据被破坏了,则数据恢复只需要星期的完全备份和星期四的差量备份。
增量备份和差异备份的区别:增量备份需要保留所有增量备份的数据;差异备份只需要保留最后一次差异备份的数据。
三、恢复
恢复就是发生故障后,利用已备份的数据文件或控制文件,重新建立一个完整的数据库。恢复分为两种类型:
1、实例恢复:当Oracle实例出现失败后,Oracle自动进行的恢复。
2、介质恢复:当存放数据库的介质出现故障时所做的恢复。介质恢复又分为完全恢复和不完全恢复。
完全恢复:将数据库恢复到数据库失败时的状态。
不完全恢复:将数据库恢复到数据库失败前的某一时刻的状态。
四、导出
(一)使用数据泵技术:
1、expdp的导出方式:
1)数据库方式:整个数据被导入到操作系统文件中。
2)用户模式:导出一个或者多个用户下的所有数据和元数据。
3)表方式:到处一组表的所有数据和元数据。
4)表空间方式:用于提取一个表空间中所有的数据和元数据,另外还提取依赖于指定表空间列表中所有对象的任何依赖对象。
转储文件:由数据泵到处程序所创建的文件成为转储文件,在单个数据泵导出作业期间所有的转储文件称为转储文件集。
2、基于命令行导出
语法:
c:\expdb system/password directory=pbdir dumpfile=pb.dmp full=y tables=table_list tablespaces=tablesapce_list schemas=schema_list remap_schema=user1:user2 nologfile=y sqlfile=pb.sql
system/passwrod:用户名和密码
directory:数据库目录对象
dumpfile:指定转储文件
full=y:表示实施的全部导入
tables=table_list:表示导入表的列表
schemas=schema_list:表示导入的用户模式
tablespaces=tablesapce_list:表示导入的表空间
remap_schema=user1:user2:表示从user1导入到user2中
nologfile=y:表示不进行日志操作
sqlfile:表示将元数据(DDL语句)写入到指定文件中。
注意:如果需要导出完全数据库,必须具备exp_full_database权限。
1)数据库方式:
注意:如果需要导出完全数据库,必须具备exp_full_database权限。
expdp scott/scott@accp directory=dump_dir dumpfile=full.dmp full=y
2)用户模式方式:
expdp scott/scott@accp directory=dump_dir dumpfile=scottschema.dmp schemas=scott
3)表导出方式:
expdp scott/scott@accp directory=dump_dir dumpfile=tables.dmp tables=emp,dept,bonus,salgrade content=data_only
说明:
content=data_only:data_only表示只导出表中的数据,不导出元数据;metadata_only:则表示只导出元数据而不导出表中的数据。如果不写,则两者全部导出。
4)表空间导出方式:
expdp scott/scott@accp directory=dump_dir dumpfile=tablespace.dmp tablespaces=users
3、DBMS_DATAPUMP进行数据泵导出
使用这种方式比直接使用命令方式要麻烦一些,但是却从数据库作业调度中安排数据泵导出作业的运行日程提供了方便,为数据泵导出提供了更好的功能度和控制度。
declare
--创建数据泵工作句柄
h1 NUMBER;
begin
--建立一个用户定义的数据泵做schema的方案备份。
h1 := DBMS_DATAPUMP.open(operation => 'export',job_mode => 'schema');
--定义存储文件
DBMS_DATAPUMp.add_file(handle => h1,filename => 'es_shop.dmp');
--定义过滤条件
DBMS_DATAPUMP.metadata_filter(handle => h1,name => 'schema_expr',value => 'in''SHOP_USER''');
--启动数据泵会话
DBMS_DATAPUMP.start_job(handle => h1);
--断开数据泵会话
DBMS_DATAPUMP.detach(handle => h1);
end; --默认保存路径:C:\Oracle11g\admin\orcl\dpdump
五、导入
(一)数据泵导入模式
1、导出方式
1)全部导入模式:一个导出文件集的全部内容被装入,该导出文件集不一定是全数据库方式进行导出的。
2)用户模式:指定文件集中的一个用户列表的全部内容被导入。
3、表模式:指定表和相依对象从导出文件中得到导入。
4、表空间模式:指定文件集中属于表空间列表内的所有内容都被导入。
2、使用命令行导入
语法:
c:\impdp system/password directory=pbdir dumpfile=pb.dmp full=y tables=table_list tablespaces=tablesapce_list schemas=schema_list remap_schema=user1:user2 nologfile=y sqlfile=pb.sql
system/passwrod:用户名和密码
directory:数据库目录对象
dumpfile:指定转储文件
full=y:表示实施的全部导入
tables=table_list:表示导入表的列表
schemas=schema_list:表示导入的用户模式
tablespaces=tablesapce_list:表示导入的表空间
remap_schema=user1:user2:表示从user1导入到user2中
nologfile=y:表示不进行日志操作
sqlfile:表示将元数据(DDL语句)写入到指定文件中。
例:
1)导入整个数据库:
impdp scott/scott@accp directory=dump_dir dumpfile=FULL.DMP full=y
2)导入表空间:
impdp scott/scott@accp directory=dump_dir dumpfile=tablespace.DMP tablespaces=mytest
3)导入scott用户下的所有表:
impdp scott/scott@accp directory=dump_dir dumpfile=TABLES.DMP tables=emp,dept,bonus,salgrade
4)将导出的scott用户下的dept和emp表导入到mytest用户下
impdp scott/scott@accp directory=dump_dir dumpfile=SCHEMA.DMP tables=dept,emp remap_schema=scott:mytest
3、DBMS_DATAPUMP进行数据泵导入
declare
--创建数据泵句柄
h1 NUMBER;
begin
--建立一个用户定义的数据泵通过数据泵连接orcllib进行访问。
h1 := DBMS_DATAPUMP.open(operation => 'IMPORT',job_mode => 'schema',remote_link => 'orcllib');
--把shop_dev_data对象模式导入到shop_back对象模式中。
DBMS_DATAPUMP.metadata_remap(handle => h1,name => 'REMAP_SCHEMA',old_value => 'SHOP_DEV_DATA',value => 'SHOP_BACK');
--将日志写入shop.log文件中
DBMS_DATAPUMP.add_file(handle => h1,filename => 'shop.log',filetype => DBMS_DATAPUMP.KU$_FILE_TYPE_LOG_FILE);
--启动数据泵
DBMS_DATAPUMP.start_job(handle => h1);
--断开数据泵连接
DBMS_DATAPUMP.detach(handle => h1);
end;
Oracle基础 数据库备份和恢复的更多相关文章
- Sql Server数据库备份和恢复:原理篇
本文与您探讨为什么Sql Server有完整备份.差异备份和事务日志备份三种备份方式,以及为什么数据库又有简单模式.完整模式和大容量日志模式这三种恢复模式.本文内容适用于2005以上所有版本的Sql ...
- 使用exp&imp工具进行数据库备份及恢复
使用exp&imp工具进行数据库备份及恢复1.exp/imp使用方法介绍exp/imp为一种数据库备份恢复工具,也可以作为不同数据库之间传递数据的工具,两个数据库所在的操作系统可以不同.exp ...
- [原创]Oracle 12c的备份和恢复策略
Oracle 12c的备份和恢复策略(RMAN备份[开启归档/控制文件/数据文件/归档日志]): 备份策略: * 每半年做一个数据库的全备份(包括所有的数据和只读表空间) * 每周做一次零级备份 * ...
- Oracle简单的备份和恢复-导出和导入(1)
ylbtech-Oracle:Oracle简单的备份和恢复-导出和导入(1) Oracle简单的备份和恢复-导出和导入 1. 用户导出自己的表(emp,dept)返回顶部 1.1, 我们启动Oracl ...
- Oracle简单的备份和恢复-导出和导入(2)
ylbtech-Oracle:Oracle简单的备份和恢复-导出和导入(2) 简单的备份和恢复-导出和导入(2) 1. 用户导入导出文件中的一张表(emp)返回顶部 0.1, 我们在sql plus中 ...
- Oracle简单的备份和恢复-导入和导出-目录
ylbtech-Oracle:Oracle简单的备份和恢复-导入和导出-目录 Oracle安全运行离不开良好的备份和恢复机制,因为我们不是DBA.所以我们也就不过多的讲解DBA的备份和恢复.作为程序员 ...
- MongoDB学习总结(六) —— 数据库备份和恢复
我们都知道数据库数据经常备份是多么的重要,MongoDB作为一个数据库系统,自然提供了完善,丰富而且好用的备份与恢复机制. 以下介绍三种数据库备份和恢复的方式 > 数据目录直接拷贝 数据库目录直 ...
- asp.net针对SQLSERVER数据库备份和恢复的一揽子问题解决
一.备份 先备份到服务端,用gridview显示出来,点击可以下载到本地 二.恢复 这是很麻烦的事情,本人查阅不少资料,耗费不少时间才搞定. 直接恢复数据库时不行的,会提示数据库正在使用,恢复失败等信 ...
- 小型网站MYSQL问题二:Percona Xtrabackup实现数据库备份和恢复
1.安装软件仓库(不要问我为什么不用源码安装,好吧,其实我懒.) 1 2 3 4 5 6 7 8 wget https://www.percona.com/downloads/percona-rele ...
随机推荐
- Java 理论与实践: 流行的原子——新原子类是 java.util.concurrent 的隐藏精华(转载)
简介: 在 JDK 5.0 之前,如果不使用本机代码,就不能用 Java 语言编写无等待.无锁定的算法.在 java.util.concurrent 中添加原子变量类之后,这种情况发生了变化.请跟随并 ...
- android手机ping不通linux的ip地址
我的linux是装载虚拟机里的,修改虚拟机的网络连接方式为桥接模式即可.
- libcurl API:CURLOPT_REFERER的用法
1.当你用libcurlAPI来请求某些数据时,发现返回的数据是0,这时候你就要去尝试用CURLOPT_REFERER来伪造一个来路页面:具体设置什么值可以通过浏览器来获取:按f12,在network ...
- TCP/IP协议族-----13、运输层简单介绍
watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvaGVrZXdhbmd6aQ==/font/5a6L5L2T/fontsize/400/fill/I0JBQk ...
- 转换到 COFF 期间失败: 文件无效或损坏 解决方法
转自csdn 终极解决方案:VS2010在经历一些更新后,建立Win32 Console Project时会出“error LNK1123” 错误,解决方案为将 项目|项目属性|配置属性|清单工具|输 ...
- C#中简单调用MD5方法以及MD5简介
MD5简介: MD5的全称是Message-Digest Algorithm 5,在90年代初由MIT的计算机科学实验室和RSA Data Security Inc发明,经MD2.M ...
- hdu4336 Card Collector 概率dp(或容斥原理?)
题意: 买东西集齐全套卡片赢大奖.每个包装袋里面有一张卡片或者没有. 已知每种卡片出现的概率 p[i],以及所有的卡片种类的数量 n(1<=n<=20). 问集齐卡片需要买东西的数量的期望 ...
- UTF-8 BOM(EF BB BF)
原标题:link标签和script标签跑到body下面,网页顶部有空白,出现“锘匡豢”乱码,UTF-8 BOM,EF BB BF 来自:http://tunps.com/link-and-script ...
- Mac下PHP环境的搭建
Mac下PHP环境的搭建 目录 Mac下PHP环境的搭建(基于XAMPP) phpmyadmin Mac下PHP环境的搭建(基于XAMPP) 下载XAMPP的Mac版 启动Apache Web Ser ...
- C++基础之预处理命令
目录 概述——对预处理命令的理解 预处理命令的处理时间 C++中主要的预处理命令 宏定义 “文件包含”处理 选择编译 概述 使用C++的预处理命令可以提高程序的可维护性,有利于程序员以更加方便和快捷的 ...