一、为什么需要数据备份

  造成数据丢失的主要原因:

  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基础 数据库备份和恢复的更多相关文章

  1. Sql Server数据库备份和恢复:原理篇

    本文与您探讨为什么Sql Server有完整备份.差异备份和事务日志备份三种备份方式,以及为什么数据库又有简单模式.完整模式和大容量日志模式这三种恢复模式.本文内容适用于2005以上所有版本的Sql ...

  2. 使用exp&imp工具进行数据库备份及恢复

    使用exp&imp工具进行数据库备份及恢复1.exp/imp使用方法介绍exp/imp为一种数据库备份恢复工具,也可以作为不同数据库之间传递数据的工具,两个数据库所在的操作系统可以不同.exp ...

  3. [原创]Oracle 12c的备份和恢复策略

    Oracle 12c的备份和恢复策略(RMAN备份[开启归档/控制文件/数据文件/归档日志]): 备份策略: * 每半年做一个数据库的全备份(包括所有的数据和只读表空间) * 每周做一次零级备份 * ...

  4. Oracle简单的备份和恢复-导出和导入(1)

    ylbtech-Oracle:Oracle简单的备份和恢复-导出和导入(1) Oracle简单的备份和恢复-导出和导入 1. 用户导出自己的表(emp,dept)返回顶部 1.1, 我们启动Oracl ...

  5. Oracle简单的备份和恢复-导出和导入(2)

    ylbtech-Oracle:Oracle简单的备份和恢复-导出和导入(2) 简单的备份和恢复-导出和导入(2) 1. 用户导入导出文件中的一张表(emp)返回顶部 0.1, 我们在sql plus中 ...

  6. Oracle简单的备份和恢复-导入和导出-目录

    ylbtech-Oracle:Oracle简单的备份和恢复-导入和导出-目录 Oracle安全运行离不开良好的备份和恢复机制,因为我们不是DBA.所以我们也就不过多的讲解DBA的备份和恢复.作为程序员 ...

  7. MongoDB学习总结(六) —— 数据库备份和恢复

    我们都知道数据库数据经常备份是多么的重要,MongoDB作为一个数据库系统,自然提供了完善,丰富而且好用的备份与恢复机制. 以下介绍三种数据库备份和恢复的方式 > 数据目录直接拷贝 数据库目录直 ...

  8. asp.net针对SQLSERVER数据库备份和恢复的一揽子问题解决

    一.备份 先备份到服务端,用gridview显示出来,点击可以下载到本地 二.恢复 这是很麻烦的事情,本人查阅不少资料,耗费不少时间才搞定. 直接恢复数据库时不行的,会提示数据库正在使用,恢复失败等信 ...

  9. 小型网站MYSQL问题二:Percona Xtrabackup实现数据库备份和恢复

    1.安装软件仓库(不要问我为什么不用源码安装,好吧,其实我懒.) 1 2 3 4 5 6 7 8 wget https://www.percona.com/downloads/percona-rele ...

随机推荐

  1. How Tomcat Works(十二)

    tomcat容器通过一个称为Session管理器的组件来管理建立的Session对象,该组件由org.apache.catalina.Manager接口表示:Session管理器必须与一个Contex ...

  2. SharePoint 2013 自定义翻页显示列表项

    项目需求:自定义开发一个能分页显示列表项的小部件,允许左右翻页,能根据用户权限来显示管理链接等. 效果如下: 技术要求:使用sharepoint rest API 来获取列表项,这样性能高,能够快速响 ...

  3. [Microsoft][ODBC SQL Server Driver][DBNETLIB]SQL Server 不存在或访问被拒绝

    一般连接sql数据库,IP_connstr="driver={SQL Server}; server=127.0.0.1;database=数据库名字;uid=sa;pwd=密码" ...

  4. android UI开源库

    . ActionBarSherlock ActionBarSherlock是一个独立的Android设计库,可以让Android 2.x的系统也能使用ActionBar.此 外,ActionBarSh ...

  5. (剑指Offer)面试题29:数组中出现次数超过一半的数字

    题目: 数组中有一个数字出现的次数超过数组长度的一半,请找出这个数字. 例如输入一个长度为9的数组{1,2,3,2,2,2,5,4,2}.由于数字2在数组中出现了5次,超过数组长度的一半,因此输出2. ...

  6. 自行架设DNS的操作步骤及相关说明

    关于什么是DNS及相关的名词及说明,请看 http://www.wdlinux.cn/bbs/viewthread.php?tid=1081&highlight=dns这里,只是说明,在wdd ...

  7. win7和linux下的文件共享

    在vmware虚拟机下安装linux系统,如果自个电脑的win7设置成自动获取IP的话,每次使用FTP文件传输服务器都要检查win7和linux系统的IP是否处于同一网段,如果不是还要手动设置.再有一 ...

  8. 有关于CSS的面试题和练习

    如果你处在一个需要面试别人有关于CSS方面技巧和知识,一时想起来还真有点难.我把我能想出来的整理在一起,提供给大家参考. 练习要做 正如他们说的,大家实际工作很重要.当然,大家通过工作练习更为重要.这 ...

  9. Sqlite表的结构修改

    Sqlite删除列方法 http://blog.csdn.net/aben_2005/article/details/6563538 SQLite3 table 结构修改 http://blog.cs ...

  10. Java学习笔记之继承

    一.继承的基础 在Java术语中,被继承的类叫超类(superclass)或者父类,继承超类的类叫子类(subclass). 举例说明: class Box { public double width ...