Oracle数据库两个用户名使用同一表空间如何备份与恢复?

Oracle数据库两个用户名使用同一表空间如何备份与恢复?,第1张

oracle备份的几种方法:\x0d\x0a1).导出/导入(EXP/IMP)。\x0d\x0a 2).热备份。\x0d\x0a 3).冷备份。\x0d\x0a 注释:导出备件是一种逻辑备份,冷备份和热备份是物理备份。\x0d\x0a 一、 导出/导入(Export/Import)\x0d\x0a 利用Export可将数据数据库中提取出来,利用Import则可将提取出来的数据送回到Oracle数据库中去。\x0d\x0a 1、简单导出数据(Export)和导入数据(Import)\x0d\x0a Oracle支持三种方式类型的输出:\x0d\x0a(1)、表方式(T方式),将指定表的数据导出。\x0d\x0aexp amis/amis@amisdb tables= B_S_AGT_LNE_ACCT_H_0714 file=B_S_AGT_LNE_ACCT_H_0714.dmp \x0d\x0aimp odsbdata/odsbdata@amisdb file= B_S_AGT_DEP_ACCT_TDE_H_0714.dmp full=y ignore=y\x0d\x0a (2)、用户方式(U方式),将指定用户的所有对象及数据导出。\x0d\x0a (3)、全库方式(Full方式),瘵数据库中的所有对象导出。\x0d\x0a 数据导入(Import)的过程是数据导出(Export)的逆过程,分别将数据文件导入数据库和将数据库数据导出到数据文件。\x0d\x0a 2、 增量导出/导入\x0d\x0a 增量导出是一种常用的数据备份方法,它只能对整个数据库来实施,并且必须作为SYSTEM来导出。导出文件名缺省为export.dmp,如果不希望自己的输出文件定名为export.dmp,必须在命令行中指出要用的文件名。\x0d\x0a 增量导出包括三种类型:\x0d\x0a (1)、“完全”增量导出(Complete)\x0d\x0a 即备份三个数据库,比如:\x0d\x0a exp system/manager inctype=complete file=040731.dmp\x0d\x0a (2)、“增量型”增量导出\x0d\x0a 备份上一次备份后改变的数据,比如:\x0d\x0a exp system/manager inctype=incremental file=040731.dmp\x0d\x0a (3)、“累积型”增量导出\x0d\x0a 累计型导出方式是导出自上次“完全”导出之后数据库中变化了的信息。比如:\x0d\x0a exp system/manager inctype=cumulative file=040731.dmp\x0d\x0a 数据库管理员可以排定一个备份日程表,用数据导出的三个不同方式合理高效的完成。\x0d\x0a 比如数据库的被封任务可以做如下安排:\x0d\x0a 星期一:完全备份(A)\x0d\x0a 星期二:增量导出(B)\x0d\x0a 星期三:增量导出(C)\x0d\x0a 星期四:增量导出(D)\x0d\x0a 星期五:累计导出(E)\x0d\x0a 星期六:增量导出(F)\x0d\x0a 星期日:增量导出(G)\x0d\x0a 如果在星期日,数据库遭到意外破坏,数据库管理员可按一下步骤来回复数据库:\x0d\x0a 第一步:用命令CREATE DATABASE重新生成数据库结构;\x0d\x0a 第二步:创建一个足够大的附加回滚。\x0d\x0a 第三步:完全增量导入A:\x0d\x0a imp system/manager inctype=RESTORE FULL=y FILE=A\x0d\x0a 第四步:累计增量导入E:\x0d\x0a imp system/manager inctype=RESTORE FULL=Y FILE=E\x0d\x0a 第五步:最近增量导入F:\x0d\x0a imp system/manager inctype=RESTORE FULL=Y FILE=F\x0d\x0a二、 冷备份\x0d\x0a 冷备份发生在数据库已经正常关闭的情况下,当正常关闭时会提供给我们一个完整的数据库。冷备份时将关键性文件拷贝到另外的位置的一种说法。对于备份Oracle信息而言,冷备份时最快和最安全的方法。冷备份的优点是:\x0d\x0a 1、 是非常快速的备份方法(只需拷文件)\x0d\x0a 2、 容易归档(简单拷贝即可)\x0d\x0a 3、 容易恢复到某个时间点上(只需将文件再拷贝回去)\x0d\x0a 4、 能与归档方法相结合,做数据库“最佳状态”的恢复。\x0d\x0a 5、 低度维护,高度安全。\x0d\x0a 但冷备份也有如下不足:\x0d\x0a 1、 单独使用时,只能提供到“某一时间点上”的恢复。\x0d\x0a 2、 再实施备份的全过程中,数据库必须要作备份而不能作其他工作。也就是说,在冷备份过程中,数据库必须是关闭状态。\x0d\x0a 3、 若磁盘空间有限,只能拷贝到磁带等其他外部存储设备上,速度会很慢。\x0d\x0a 4、 不能按表或按用户恢复。\x0d\x0a 如果可能的话(主要看效率),应将信息备份到磁盘上,然后启动数据库(使用户可以工作)并将备份的信息拷贝到磁带上(拷贝的同时,数据库也可以工作)。冷备份中必须拷贝的文件包括:\x0d\x0a 1、 所有数据文件\x0d\x0a 2、 所有控制文件\x0d\x0a 3、 所有联机REDO LOG文件\x0d\x0a 4、 Init.ora文件(可选)\x0d\x0a 值得注意的使冷备份必须在数据库关闭的情况下进行,当数据库处于打开状态时,执行数据库文件系统备份是无效的。\x0d\x0a 下面是作冷备份的完整例子。\x0d\x0a (1) 关闭数据库\x0d\x0a sqlplus /nolog\x0d\x0a sql>connect /as sysdba\x0d\x0a sql>shutdown normal;\x0d\x0a (2) 用拷贝命令备份全部的时间文件、重做日志文件、控制文件、初始化参数文件\x0d\x0a sql>cp \x0d\x0a (3) 重启Oracle数据库\x0d\x0a sql>startup\x0d\x0a 三、 热备份\x0d\x0a 热备份是在数据库运行的情况下,采用archivelog mode方式备份数据库的方法。所以,如果你有昨天夜里的一个冷备份而且又有今天的热备份文件,在发生问题时,就可以利用这些资料恢复更多的信息。热备份要求数据库在Archivelog方式下 *** 作,并需要大量的档案空间。一旦数据库运行在archivelog状态下,就可以做备份了。热备份的命令文件由三部分组成:\x0d\x0a 1. 数据文件一个表空间一个表空间的备份。\x0d\x0a (1) 设置表空间为备份状态\x0d\x0a (2) 备份表空间的数据文件\x0d\x0a (3) 回复表空间为正常状态\x0d\x0a 2. 备份归档log文件\x0d\x0a (1) 临时停止归档进程\x0d\x0a (2) log下那些在archive rede log目标目录中的文件\x0d\x0a (3) 重新启动archive进程\x0d\x0a (4) 备份归档的redo log文件\x0d\x0a 3. 用alter database bachup controlfile命令来备份控制文件\x0d\x0a 热备份的优点是:\x0d\x0a 1. 可在表空间或数据库文件级备份,备份的时间短。\x0d\x0a 2. 备份时数据库仍可使用。\x0d\x0a 3. 可达到秒级恢复(恢复到某一时间点上)。\x0d\x0a 4. 可对几乎所有数据库实体做恢复\x0d\x0a 5. 恢复是快速的,在大多数情况下爱数据库仍工作时恢复。\x0d\x0a 热备份的不足之处:\x0d\x0a 1. 不能出错,否则后果不堪设想。\x0d\x0a 2. 假如热备份不成功,所得结果则不能用于时间点的恢复(scn)。\x0d\x0a如果是全库一般需要配置一个rman.\x0d\x0aoracle的恢复方案:\x0d\x0aoracle 恢复表到以前的某个状态\x0d\x0a1.用bda登录进去\x0d\x0aselect * from sys.smon_scn_time--scn 与时间的对应关系 \x0d\x0a每隔5分钟,系统产生一次系统时间标记与scn的匹配并存入sys.smon_scn_time表。 \x0d\x0a以下是我在测试机上做了一个测试:\x0d\x0aselect * from table as of scn 3296161275\x0d\x0a\x0d\x0aselect * from table as of scn 3296200982\x0d\x0a\x0d\x0a然后我们恢复到这个检查点。\x0d\x0a以上是oracle的备份和恢复方案。

根据oracle数据库的特点和提供的工具,主要方法有以下几种方法:

利用逻辑备份使用import工具丢失数据的表

利用物理备份来通过还原数据文件并进行不完全恢复

利用dbms_logmnr包从redo log文件中恢复

利用flashback特性恢复数据

前提

为了方便使用方法的介绍,上述恢复方法都将基于以下场景进行:系统管理员在前一天晚上11点用export对数据库做了全库逻辑备份,然后对所有数据文件进行了热备份。第二天上午10点,系统管理员在修改表TFUNDASSET的数据时,由于修改语句的条件写错了,导致一批记录(几千条)的ztm字段被修改成了错误的值,而且已经提交。这个表是资产表,相对而言数据变化不频繁。

一、利用逻辑备份使用import工具恢复丢失的数据

export/import是oracle提供的用于对数据库进行逻辑备份的工具。该工具适用于备份那些数据量不大、业务量不多的数据库系统。因为如果在前一天晚上11点用export做了逻辑备份,那么当今天上午10点数据库意外崩溃时,从备份起到数据库崩溃的这段时间里的数据修改 *** 作(包括DDL和DML)都会丢失。如果丢失数据内的表上的数据是相对比较稳定,也就是说该表上基本没有DML *** 作,例如标准代码表、分区表里的历史数据,那么采用import来导入该表可以比较完整的恢复数据。如果该表是经常变化的业务表,那么这些丢失的数据只能根据业务情况从纸质记录恢复,或者其他途径恢复。

▲示例如下:这个表是一个资产表。相对来说,今天系统运行中修改的数据较少,丢失的数据量可以承受或者可以从别的途径恢复。那就可以用import来恢复。

方法一:

1、把这个表的数据备份到另一个表:

8bef9890242e5d20d09563896cef1471.png

2、删除该表的记录:

625dfa5d5986ca5c37dd5017953407cb.png

3、执行下面的命令:

3754d50cc473bd44236d927f00196d24.png

这个命令中在关键字tables中指定需要导入的表名字,ignore=y表示忽略表已经存在的错误。

4、导入结束后,检查表中的记录,并用适当的方法恢复当天的修改。

方法二:

1、 把需要恢复的表导入到另一个用户下面:

33806d1216df5ae9c45890d3d45930ee.png

2、检查数据以后,把原表记录删除:

fe23a8a4602702e951e5ab48a7460e3b.png

3、然后从另一用户表中插入回去:

729976810ef459046df40b791a6ca773.png

4、 数据量比较大时可以采用如下方法:

e377d10ff07132f160185cb1ba119cfc.png

二、利用物理备份来通过还原数据文件并进行不完全恢复

如果数据库运行在归档模式下,那么可以通过使用以前的数据文件备份进行还原,然后利用归档日志进行前滚,直到回滚到错误 *** 作的时间点前,然后重置日志文件打开数据库。

可以通过下列方法确认是否是运行在归档模式:

c8406e42aef7ccc8ef232cfdd535e825.png

如果是如上所示,那么就是运行在归档模式了。

▲假定在前一天晚上11点做了全库物理备份,那么可以考虑如下恢复:

1、关闭数据库:

由于数据库的不完全恢复必须在一个关闭的数据库上实施,利用一个旧的数据库的备份还原,然后用日志根据需要逐步前滚,而不能还原一个新的备份,再回退到某个时间点。

通知各客户端数据库将关闭,然后发出:

401f68e89cbfa03388f5913bf5f1ecfd.png

数据库已经关闭。

已经卸载数据库。

ORACLE 例程已经关闭。

2、确定错误 *** 作的时间:

可以根据 *** 作员的估计来确定不完全恢复需要前滚停止的时间,也可以利用LogMiner来分析日志文件(这个工具将在后面介绍),找出错误 *** 作的准确时间。

3、还原数据文件:

先对当前的数据库文件进行备份,然后再用以前的最近一次备份覆盖现有数据文件。注意:不覆盖现有的控制文件。

4、基于时间点恢复,启动数据库到装配状态:

8802043c250eb2a060285be160f48c36.png

这样数据库就恢复到了2015年10月20日的9点58分零秒。

然后再利用业务资料补充这段时间内的数据。

三、利用dbms_logmnr包从log文件中恢复

这个包是由Oracle提供,与dbms_logmnr_d包配合使用可以方便地分析联机日志文件和归档日志文件,从这些日志文件中提取出所有对数据库的更改 *** 作。

在使用这个包之前,需要先做一些设置和修改:

1、打开initorcl.ora,修改初始化参数utl_file_dir,设置dbms_logmnr_d包将要使用的数据字典文件的放置目录。

eb6dad504d6f5841641cbd02c5f6dee1.png

然后重启数据库使参数生效。

2、以sys用户连接到数据库执行dbmslmd.sql脚本重建dbms_logmnr_d这个包。

应用Logminer分析重做日志文件的 *** 作主要有以下步骤:

● 使用dbms_logmnr_d里的存储过程build创建一个外部数据字典文件;

● 使用dbms_logmnr里的存储过程add_logfile添加要分析的日志文件;

● 使用dbms_logmnr里的存储过程start_logmnr启动分析;

● 查询与dbms_logmnr相关的几个视图来获取日志文件内容;

● 使用dbms_logmnr里的存储过程end_logmnr结束分析。

▲下面详细讲述使用的过程

1、使用dbms_logmnr_d里的存储过程build创建一个外部数据字典文件:

a0975e25f5049f1ffdfdd49ad7ae943d.png

2、使用dbms_logmnr里的存储过程add_logfile添加要分析的日志文件到待分析文件列表:

d16ea343204a3a15b29bc6b94985d48d.png

如果没有运行在归档模式,那么由于重做日志文件的循环使用可能导致日志文件被覆盖而无法获取到所要寻找的恢复条目。如果运行在归档模式,则可以通过查看$ORACLE_HOMEadminorclbdump目录下的alert_orcl.log里日志文件归档的时间和错误 *** 作的时间来确定加入哪些归档日志文件到待分析的文件列表中去。

eff89b61175131d3edda456d8d9bc18e.png

注意:执行以上过程时logfilename参数需要写日志文件的全路径,否则会报错。重复以上 *** 作直到把所有需要分析的文件都加到列表中去。这样就可以启动进行分析。

3、使用dbms_logmnr里的存储过程start_logmnr启动分析;

3630359ea5afa57b5ea51c89da5b8c41.png

这样就可以通过下面的查询来获取日志文件的内容了。

4、查询与dbms_logmnr相关的几个视图来获取日志文件内容;

3f8098efdbe50d4b5b4a5311eab6b5d0.png

这样就可以找出要恢复所需的语句。注意:v$logmnr_contents只对执行dbms_logmnr.start_logmnr的会话有效,如果通过其他会话或者使用dbms_logmnr.end_logmnr终止了分析,都将不能访问v$logmnr_contents的数据。如果要使其他会话也能获取到这些数据,可以通过另外建表来实现,如:

create table undo_sql as select * from v$logmnr_contents。

再对undo_sql进行授权,其他用户就可以访问v$logmnr_contents的数据了。

5、使用dbms_logmnr里的存储过程end_logmnr结束分析。

使用完成以后用下面的命令来结束分析活动:exec dbms_logmnr.end_logmnr

这样就释放了分配给logminer的资源(内存和数据结构)。

从上面的过程可知,如果是更新的数据量比较大,而日志文件比较小,就可能会导致日志文件的切换。如果没有及时去挖掘日志文件(没有运行在归档模式),那么可能会由于日志文件的循环使用而导致数据不可恢复。如果运行在归档模式,也可能由于需要分析的日志文件比较多而时间较长。

四、利用flashback新特性恢复数据

Oracle9i 开始提供了闪回查询(Flashback Query)功能,对于误删除或者误更新并且已经commit了的情况提供了简便快捷的恢复方法;而在Oracle 提供闪回查询之前,碰到这种情况只能通过备份来进行基于时间点的恢复或者使用logmnr挖掘日志来恢复,无疑这比闪回查询要麻烦而且费时。

使用这个Flashback Query特性的前提条件:

1. 数据库必须处于Automatic Undo Management 状态。

9d9facd0a8d3e8675284d38f601525d1.png

2. 最大可以闪回查询的时间段由UNDO_RETENTION 初始化参数(单位为秒)指定

b7a419e2f47bd4d31005ca2d9b4a7c58.png

可以通过ALTER SYSTEM SET UNDO_RETENTION = 来动态修改参数值。

▲如何使用Flashback Query来恢复数据呢?

1. 通过SQL

28b1053a806762ec87261e80f0e8751f.png

使用SELECT 语句的AS OF 来进行闪回查询,语法如下:

使用AS OF 关键字来对表,视图或者物化视图进行Flashback Query,如果指定了SCN,那么expr 部分必须是一个数字,如果指定了TIMESTAMP,那么expr 必须是一个timestamp类型的值。查询结果将返回在指定的SCN 或者时间点上的数据。

下面我们使用scott 方案来作一个实验。

24547dbf2f8f3515319435d98acc0f10.png

如果想在update 的子查询部分使用AS OF,那么该查询只能返回一条记录,否则将会报错。

可以通过添加一个临时表作为中转,然后再作更新,如下:

5605ae591ab357c7148787937df03e17.png

2.通过DBMS_FLASHBACK包来恢复

DBMS_FLASHBACK 包提供了以下几个函数:

ENABLE_AT_TIME:设置当前SESSION 的闪回查询时间

ENABLE_AT_SYSTEM_CHANGE_NUMBER:设置当前SESSION 的闪回查询SCN

GET_SYSTEM_CHANGE_NUMBER:取得当前数据库的SCN

DISABLE:关闭当前SESSION 的闪回查询

当将一个SESSION 设置为闪回查询模式之后,后续的查询都会基于那个时间点或者SCN 的数据库状态,如果SESSION 结束,那么即使没有明确指定DISABLE,闪回查询也会自动失效。

当SESSION 运行在闪回查询状态时,不允许进行任何DML 和DDL *** 作。如果要用DML *** 作来进行数据恢复就必须使用PL/SQL 游标。

▲示例:

fbaf8acfe357d8f21039d588c8b658df.png

通过上面的例子可以看出,只要这个修改的时间不早于sysdate- (UNDO_RETENTION指定的秒数),就可通过这种方式来恢复数据。

e93c4d7b11cf4e7c8ed9a0d27c79ea80.png

对于问题中的批量数据,可以写个过程来完成获取到更改前的数据:

然后再用这个临时表里的数据来更新TFUNDASSET就可以了。

五、总结

比较以上几种恢复数据的方法的使用过程,我们可以看出:

● exp/imp只适合于数据变化不大的表的数据丢失的情况,即使用这种方法处理后也需要从业务办理资料中修正数据,否则导致数据丢失;

● 采用基于时间点的不完全恢复可以恢复丢失的数据,但是需要关关闭数据库,减少系统可用时间,而且也会丢失恢复时间点以后的数据;

● 使用LogMiner可以较好的恢复数据,但是要求数据库尽可能运行在归档模式,否则也可能导致数据丢失。好处是不用关闭系统,能够从日志文件中得到所有的数据。

● 使用Flashback最方便和简洁,可以直接得到修改前的数据,但是需要依赖系统设置,并且需要占用大量的回滚表空间。

因此选择什么样的方法来恢复数据,取决于你的系统环境和具体情况,不能生搬硬套。采用正确的方法才能最大程度的减少数据的丢失。

当然,最好是不需要用到这些恢复的办法。前提是,你必须做好以下的工作:

1、 为不同环境创建不同的数据库用户、不同密码(如果不能用户不同,一定要密码不同);

2、 将owner和应用用户分开,并做适度授权;

3、 在做DML前,先用同样的条件做查询,看根据结果集是否符合预期。

Oracle数据库不能恢复到特定的时间是因为Oracle的redo log并不保存每一次事务 *** 作,而是将所有 *** 作放在一起,当redolog文件被重写或者被标记为inactive时,数据库就不能复原到特定时间点,只能复原到执行最后一次备份之前的数据状态。


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/9977121.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-04
下一篇 2023-05-04

发表评论

登录后才能评论

评论列表(0条)

保存