今天被吊,特来学习备份。

https://blog.csdn.net/zhaiqi618/article/details/5616215

https://www.cnblogs.com/yingpp/archive/2009/01/07/1371040.html

Oracle数据库有三种标准的备份方法,它们分别是导出/导入(EXP/IMP)、热备份和冷备份。导出备件是一种逻辑备份,冷备份和热备份是物理备份。

一、 导出/导入(Export/Import)

利用Export可将数据从数据库中提取出来,利用Import则可将提取出来的数据送回到Oracle数据库中去。

1、 简单导出数据(Export)和导入数据(Import)

Oracle支持三种方式类型的输出:

(1)、表方式(T方式),将指定表的数据导出。

(2)、用户方式(U方式),将指定用户的所有对象及数据导出。

(3)、全库方式(Full方式),瘵数据库中的所有对象导出。

1. 将数据库完全导出
    用户名system 密码system 导出到Oracle用户目录下的testdb20100522.dmp文件中
    #exp system/system@testdb file=testdb20100522.dmp full=y
2. 将数据库中system用户与sys用户的表导出
    #exp system/system@testdb file= testdb20100522.dmp owner=(system,sys)
3. 将数据库中的表inner_notify、notify_staff_relat导出
    #exp aichannel/aichannel@testdb file= testdb20100522.dmp tables=(inner_notify,notify_staff_relat)
4. 将数据库中的表table1中的字段filed1以"00"打头的数据导出
    #exp system/manager@TEST file= testdb20100522.dmp tables=(table1) query=" where filed1 like '00%'"
    上面是常用的导出,用命令可以把dmp文件可以很好的压缩,也可以在上面命令后面 加上 compress=y 来实现。
5. 将testdb20100522.dmp 中的数据导入sdpdb数据库中
    #imp system/system@testdb  file=testdb20100522.dmp
    #imp system/system@testdb full=y  file= testdb20100522.dmp ignore=y
    上面可能有点问题,因为有的表已经存在,然后它就报错,对该表就不进行导入,在后面加上 ignore=y 就可以了。
6. 将testdb20100522.dmp中的表table1 导入
    #imp system/system@testdb  file=testdb20100522.dmp  tables=(table1)
    基本上上面的导入导出够用了。不少情况要先是将表彻底删除,然后导入。

经常遇见的错误是新的数据库必须要有原数据库的表空间,需要先自己建立表空间,而且有可能在旧数据库里面的表空间以外,导入的dump还需要其他表空间,需要根据自己来确认创建。

数据导入(Import)的过程是数据导出(Export)的逆过程,分别将数据文件导入数据库和将数据库数据导出到数据文件。

2、 增量导出/导入

增量导出是一种常用的数据备份方法,它只能对整个数据库来实施,并且必须作为SYSTEM来导出。在进行此种导出时,系统不要求回答任何问题。导出文件名缺省为export.dmp,如果不希望自己的输出文件定名为export.dmp,必须在命令行中指出要用的文件名。

增量导出包括三种类型:

(1)、“完全”增量导出(Complete)

即备份三个数据库,比如:

<ccid_nobr>

<ccid_code>exp system/manager inctype=complete file=040731.dmp

(2)、“增量型”增量导出

备份上一次备份后改变的数据,比如:

<ccid_nobr>

<ccid_code>exp system/manager inctype=incremental file=040731.dmp

(3)、“累积型”增量导出

累计型导出方式是导出自上次“完全”导出之后数据库中变化了的信息。比如:

<ccid_nobr>

<ccid_code>exp system/manager inctype=cumulative file=040731.dmp

数据库管理员可以排定一个备份日程表,用数据导出的三个不同方式合理高效的完成。

比如数据库的被封任务可以做如下安排:

星期一:完全备份(A)

星期二:增量导出(B)

星期三:增量导出(C)

星期四:增量导出(D)

星期五:累计导出(E)

星期六:增量导出(F)

星期日:增量导出(G)

如果在星期日,数据库遭到意外破坏,数据库管理员可按一下步骤来回复数据库:

第一步:用命令CREATE DATABASE重新生成数据库结构;

第二步:创建一个足够大的附加回滚。

第三步:完全增量导入A:

<ccid_nobr>

<ccid_code>imp system/manager inctype=RESTORE FULL=y FILE=A

第四步:累计增量导入E:

<ccid_nobr>

<ccid_code>imp system/manager inctype=RESTORE FULL=Y FILE=E

第五步:最近增量导入F:

<ccid_nobr>

<ccid_code>imp system/manager inctype=RESTORE FULL=Y FILE=F

二、 冷备份

冷备份发生在数据库已经正常关闭的情况下,当正常关闭时会提供给我们一个完整的数据库。冷备份时将关键性文件拷贝到另外的位置的一种说法。对于备份Oracle信息而言,冷备份时最快和最安全的方法。冷备份的优点是:

1、 是非常快速的备份方法(只需拷文件)

2、 容易归档(简单拷贝即可)

3、 容易恢复到某个时间点上(只需将文件再拷贝回去)

4、 能与归档方法相结合,做数据库“最佳状态”的恢复。

5、 低度维护,高度安全。

但冷备份也有如下不足:

1、 单独使用时,只能提供到“某一时间点上”的恢复。

2、 再实施备份的全过程中,数据库必须要作备份而不能作其他工作。也就是说,在冷备份过程中,数据库必须是关闭状态。

3、 若磁盘空间有限,只能拷贝到磁带等其他外部存储设备上,速度会很慢。

4、 不能按表或按用户恢复。

如果可能的话(主要看效率),应将信息备份到磁盘上,然后启动数据库(使用户可以工作)并将备份的信息拷贝到磁带上(拷贝的同时,数据库也可以工作)。冷备份中必须拷贝的文件包括:

1、 所有数据文件

2、 所有控制文件

3、 所有联机REDO LOG文件

4、 Init.ora文件(可选)

值得注意的使冷备份必须在数据库关闭的情况下进行,当数据库处于打开状态时,执行数据库文件系统备份是无效的。

下面是作冷备份的完整例子。

(1) 关闭数据库

<ccid_nobr>

<ccid_code>sqlplus /nolog
sql>;connect /as sysdba
sql>;shutdown normal;

(2) 用拷贝命令备份全部的时间文件、重做日志文件、控制文件、初始化参数文件

<ccid_nobr>

<ccid_code>sql>;cp <file>; <backup directory>;

(3) 重启Oracle数据库

<ccid_nobr>

<ccid_code>sql>;startup

三、 热备份

热备份是在数据库运行的情况下,采用archivelog mode方式备份数据库的方法。所以,如果你有昨天夜里的一个冷备份而且又有今天的热备份文件,在发生问题时,就可以利用这些资料恢复更多的信息。热备份要求数据库在Archivelog方式下操作,并需要大量的档案空间。一旦数据库运行在archivelog状态下,就可以做备份了。热备份的命令文件由三部分组成:

1. 数据文件一个表空间一个表空间的备份。

(1) 设置表空间为备份状态

(2) 备份表空间的数据文件

(3) 回复表空间为正常状态

2. 备份归档log文件

(1) 临时停止归档进程

(2) log下那些在archive rede log目标目录中的文件

(3) 重新启动archive进程

(4) 备份归档的redo log文件

3. 用alter database bachup controlfile命令来备份控制文件

热备份的优点是:

1. 可在表空间或数据库文件级备份,备份的时间短。

2. 备份时数据库仍可使用。

3. 可达到秒级恢复(恢复到某一时间点上)。

4. 可对几乎所有数据库实体做恢复

5. 恢复是快速的,在大多数情况下爱数据库仍工作时恢复。

热备份的不足是:

1. 不能出错,否则后果严重

2. 若热备份不成功,所得结果不可用于时间点的恢复

3. 因难于维护,所以要特别仔细小心,不允许“以失败告终”。

export 有四种备份方式:完全,表空间,用户,表

exp [user]/[passwd]@[servername] file=文件路径 log=日志路径

例如:exp system/manager@10g file=d:\expdata.dmp log=d:\expdata.log full=y

物理性质的将数据库从PCA转移到PCB上

操作步骤

1、两台电脑系统的目录结构一样

本次实现的目录结构是/opt/oracle

2、数据库关闭在sqlplus 中输入shutdown immediate

[oracle@uid5a1 oracle]$ sqlplus / as sysdba
SQL>shutdown  immediate;
SQL>exit;
3、假定我们要复制的数据库的计算机名称叫A ,目标数据库叫B
复制A计算机中的/opt/oracle下面的admin、diag、flash_recovery_area、oradata四个文件夹
复制ORACLE_HOME下面的启动文件和密码文件,opt/oracle/product/OraHome/dbs下面的ora*.*,spfile*.*
复制到相关的存储介质上(如U盘上)

注意:
复制的前提是数据库一定要处于shutdown状态
有些数据文件如果不是放在oradata下面的如果有需要也要一起复制走,要不后面启动的时候会出现
ORA-01157,数据库错误
 
复制完之后,可以在sqlplus中输入startup,启动数据库
3、将相关数据复制到相对应的目标计算机B磁盘位置上,然后在sqlplus
中输入startup就可以了。
注意:位置要一样

如果有些数据库文件忘记复制了,会出现
ORA-01157: 无法标识/锁定数据文件-请参阅DBWR跟踪文件
ORA-01110:数据文件 '/home/x.dbf'
ORA-01157: cannont identify /lock data file string -see DBWR trace file
ORA-01110:data file :'/home/x.dbf'
解决办法
alter database datafile '/home/x.dbf' offline drop
alter database open  或者 startup
就可以了

如果说要执行RMAN相关的操作,要修改其中的一台的DBID,否则RMAN不能够执行。

步骤如下:

1、   在SQLPLU中输入shutdown immediate

2、   在SQLPLUS中输入startup mount;

3、   在SQLPLUS中输入exit

4、   在终端中输入nid
target=sys/password@shilimin然后输入Y就行了。

http://tech.it168.com/a2008/0822/201/000000201553_all.shtml

Oracle备份的更多相关文章

  1. Oracle 备份与还原

    oracle 备份与还原 一.备份数据库(exp) 1.完全备份 exp demo/demo@orcl buffer=1024 file=d:\back.dmp full=y demo:用户名.密码 ...

  2. Oracle备份及备份策略

    第二章. 了解备份的重要性 可以说,从计算机系统出世的那天起,就有了备份这个概念,计算机以其强大的速度处理能力,取代了很多人为的工作,但是,往往很多时候,它又是那么弱不禁风,主板上的芯片.主板电路.内 ...

  3. 基于Linux下catalog方式的 Oracle 备份策略(RMAN)

    --********************************** -- 基于Linux下 Oracle 备份策略(RMAN) --******************************* ...

  4. Actifio中如何分析Oracle备份恢复的报错

    场景不同,可以分析的日志不同. 有关oracle备份 (L0/L1) 或者Oracle Log smart backups的日志:UDSAgent.log (on target host locate ...

  5. Oracle 备份、恢复单表或多表数据步骤

    Oracle 备份.恢复单表或多表数据步骤,适用于 Oracle 8.9.10.        *备份单表或多表数据: exp user/password@server file=filefullpa ...

  6. Oracle 备份恢复实例

    Oracle 备份恢复实例:三思笔记 1 shutdown abort 系统归档模式,有备份 create table xx as select * from emp; update xx set e ...

  7. C#oracle备份和还原

    最近公司的oracle备份工具不好使了,原来是公司的人用VB写的,由于我是主攻C#的,所以想着自己来写一个C#版本的oracle备份和还原工具. 一开始,我按照原来的设计思路来进行编写,想在pluss ...

  8. oracle备份表和数据

    oracle 备份数据 如果备份表存在 原表t_base_employee,备份表t_base_employee20180718 insert into t_base_employee0718 sel ...

  9. oracle 备份/恢复

    oracle备份是为了有问题能够快速恢复:

  10. [转帖]oracle备份恢复之recover database的四条语句区别

    oracle备份恢复之recover database的四条语句区别 https://www.cnblogs.com/andy6/p/5925433.html 需要学习一下. 1  recover d ...

随机推荐

  1. 详解 Solidity 事件Event - 完全搞懂事件的使用

    很多同学对Solidity 中的Event有疑问,这篇文章就来详细的看看Solidity 中Event到底有什么用? 写在前面 Solidity 是以太坊智能合约编程语言,阅读本文前,你应该对以太坊. ...

  2. 小程序授权demo

    <button wx:if="{{canIUse}}"   open-type="getUserInfo"  bindgetuserinfo=" ...

  3. CentOS7 安装PHP7的redis扩展:

      phpredis-4.2.0.tar.gz:下载:wget https://github.com/phpredis/phpredis/archive/4.2.0.tar.gz   $ tar -z ...

  4. DRF之接口文档以及Xadmin

    1. 自动生成接口文档 REST framework可以自动帮助我们生成接口文档. 接口文档以网页的方式呈现. 自动接口文档能生成的是继承自APIView及其子类的视图. 1.1. 安装依赖 REST ...

  5. HDu4794 斐波那契循环节

    题意:Arnold变换把矩阵(x,y)变成((x+y)%n,(x+2*y)%n),问最小循环节 题解:仔细算前几项能看出是斐波那契数论modn,然后套个斐波那契循环节板子即可 //#pragma GC ...

  6. 5月17 AJAX返回类型-------JSON和XML

    ajax返回类型有TEXT,JSON,XML 一.TEXT 查看之前的练习 二.JSON var js = { aa:{code:"p001",name:"张三" ...

  7. 笔记react router 4(三)

    上一篇我们说到了路由组件的嵌套.想必你已经运用自如了.那么,这一次我们来聊一聊4.X中Router的变更. 在3.X中我们若使用路由的模式,可通过在Router上配置history的值即可. 例如, ...

  8. TCP如何保证可靠性

    如何保证可靠性? 1.校验和.在TCP的首部中有一个占据16为的空间用来放置校验和的结果. 这是一个端到端的检验和,目的是检测数据在传输过程中的任何变化.如果收到段的检验和有差错,TCP将丢弃这个报文 ...

  9. Git冲突:commit your changes or stash them before you can merge.

    用git pull来更新代码的时候,遇到了下面的问题: error: Your local changes to the following files would be overwritten by ...

  10. IDEA 错误:找不到或无法加载主类

    下的java核心编程的源码,只有java文件,没有idea或者eclipse的项目结构信息. 分别用eclipse和idea打开了一遍,方便学习调试. 项目文件夹:E:\学习资料\Java\语法\ja ...