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

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. Bitmap Byte[] 互转

    严正声明:作者:psklf出处: http://www.cnblogs.com/psklf/p/5889978.html欢迎转载,但未经作者同意,必须保留此段声明:必须在文章中给出原文连接:否则必究法 ...

  2. yarn hadoop-2.3.0 installation cluster Centos 64bits

    Apache Hadoop -2.2.0 - How to Install a Three Nodes Cluster http://tonylixu.blogspot.ca/2014/02/apac ...

  3. 迷宫最短路径问题的dfs,bfs实现

    迷宫的最短路径 给定一个大小为 N×M的迷宫.迷宫由通道和墙壁组成,每一步可以向邻接的上下左右四格的通道移动.请求出从起点到终点所需的小步数.请注意,本题假定从起点一定可以移动到终点 限制条件:N,M ...

  4. [洛谷 P3239] [HNOI2015]亚瑟王

    [HNOI2015]亚瑟王 题目描述 小 K 不慎被 LL 邪教洗脑了,洗脑程度深到他甚至想要从亚瑟王邪教中脱坑.他决定,在脱坑之前,最后再来打一盘亚瑟王.既然是最后一战,就一定要打得漂亮.众所周知, ...

  5. [洛谷 P3787] 冰精冻西瓜

    题目描述 琪露诺是拥有操纵冷气程度的能力的妖精,一天她发现了一片西瓜地.这里有n个西瓜,由n-1条西瓜蔓连接,形成一个有根树,琪露诺想要把它们冷冻起来慢慢吃. 这些西瓜蔓具有神奇的性质,可以将经过它的 ...

  6. Linux -- 基于zookeeper的java api(二)

    Linux -- 基于zookeeper的java api(二) 写一个关于基于集群的zookeeper的自定义实现HA 基于客户端和监控器:使用监控的方法查看每个注册过的节点的状态来做出操作. Wa ...

  7. 基于TcpListerer的web服务器 和 基于HttpListerer的web服务器

    摘自<Asp.Net 本质论>作者:郝冠军 /* 为了简化基于TCP协议的监听程序,.NET在System.Net.Sockets命名空间中提供了TcpListerer类,使用它,在构造函 ...

  8. linux LVM详解

    1.创建及删除步骤1)创建:linux partition-->pv-->vg-->lv-->fs-->mount2)删除:umount-->lv-->vg- ...

  9. Windows平台dump文件的产生,调试;工程配置pdb文件怎么生成

    http://blog.csdn.net/byxdaz/article/details/25872151

  10. 由于 Exception.tostring()失败,因此无法打印异常字符串

    console程序执行错误时,不显示异常信息. 解决方法: 在命令行修改显示字符格式  chcp 936