Oracle的闪回特性
14-第14章:闪回技术
第14章 闪回技术
朱广强 zgq007@
主要内容
闪回技术概述 闪回技术查询 闪回版本查询 闪回表 闪回事务查询 闪回数据库 闪回数据归档
2
闪回技术概述
flashback( 闪 回 ) 是 Oracle10g 里 新 加 入 的 一 个 非 常 有 用 的 一 个 特 性 。 Oracle数据库10g提供了五个新的闪回功能:闪回版本查询,闪回事务查询,闪 回删除,闪回表和闪回数据库。Oracle数据库11g提供了一个有趣的新的闪回功 能:闪回数据存档,它允许一个Oracle数据库管理员维护一个记录,对指定时 Nhomakorabea9
闪回删除(Flashback Drop)
闪回删除(Flashback Drop) 使用 Oracle Database 11g中的闪回表特性,可以毫不费力地恢复被意外删除的表。 如果用户或DBA意外地删除了一个非常重要的表,需要尽快地恢复。虽然Oracle 9i D atabase 推出了闪回查询选项的概念,以便检索过去某个时间点的数据,但它不能闪回 DDL 操作,如删除表的操作。唯一的恢复方法是在另一个数据库中使用表空间的时间点 恢复,然后使用导出/导入或其他方法,在当前数据库中重新创建表。这一过程需要 DB A 进行大量工作并且耗费宝贵的时间,更不用说还要使用另一个数据库进行克隆。 现在使用 Oracle Database 11g中的闪回表特性,它使得被删除表的恢复过程如同执行 几条语句一样简单。 闪回删除可恢复使用DROP TABLE语句删除的表,是一种对意外删除的表的恢复机制。 闪回删除功能的实现主要是通过Oracle 11g数据库中的“回收站”(Recycle Bin)技术实现 的。 在Oracle 11g数据库中,当执行DROP TABLE操作时,并不立即回收表及其关联对象的 空间,而是将它们重命名后放入一个称为“回收站”的逻辑容器中保存,直到用户决定 永久删除它们或存储该表的表空间存储空间不足时,表才真正被删除。 注意:为了使用闪回删除技术,必须开启数据库的“回收站”。
oracle中闪回语法
oracle中闪回语法全文共四篇示例,供读者参考第一篇示例:Oracle中的闪回功能是一种强大的特性,它可以让用户在数据库操作出现错误时快速恢复数据到之前的状态。
通过使用闪回功能,用户可以在不影响其他正在运行的事务的情况下,进行数据的回滚操作,使数据库恢复到之前一个确定的时间点。
在Oracle中,闪回功能主要通过闪回查询和闪回表来实现。
闪回查询可以让用户查看数据库在某个时间点的数据情况,而闪回表可以让用户将表恢复到之前的状态。
下面我们来详细介绍一下这两种闪回功能的具体语法和用法。
闪回查询的语法如下:```SELECT * FROM table_name AS OF TIMESTAMP timestamp;```这条SQL语句表示从指定的时间戳timestamp时刻查看table_name表的数据情况。
用户可以使用这种方式来查看数据库在某个具体时刻的数据,从而找出误操作的原因,或者进行数据对比和分析。
除了基本的闪回查询和闪回表功能之外,Oracle中还提供了其他一些灵活的闪回功能,比如闪回查询带条件、闪回表到某个SCN号、闪回事务等。
用户可以根据具体的需求和情况,选择合适的闪回方式进行操作。
需要注意的是,闪回功能在数据库恢复和数据修复方面有着非常重要的作用,但在使用时也需要谨慎操作,以避免对数据造成更大的影响。
在使用闪回功能之前,用户最好提前做好数据备份和日志记录,以防止操作出现意外情况。
Oracle中的闪回功能是一项非常实用和强大的特性,它可以帮助用户在数据库操作出现错误时快速恢复数据,有效避免数据丢失和影响。
通过灵活运用闪回功能,可以提高数据库的稳定性和安全性,保证数据的完整和可靠性。
希望本文的介绍能够对大家有所帮助,希望大家在使用Oracle数据库时,能够充分利用闪回功能,提升数据管理的效率和水平。
第二篇示例:Oracle中的闪回语法是一种非常强大的工具,它可以帮助用户轻松地还原数据库到之前的状态。
oracle数据库闪回
而闪回技术提供了从逻辑错误中恢复的更有效和更快的方法,多数情况下,在用这种技术进行恢复时数据库仍然联机并对用户可用。此外,闪回技术允许选择性地复原某些对象。使用传统的技术,从某种意义上说某有选择,只能恢复整个数据库。
SQL> conn rocky/rocky
已连接。
SQL> select * from emp;
EID NAME SEX ID
---------- ---------- ----- ----------
aa bb B 11
闪回数据库
闪回数据库的条件
1、 数据库日志系统必须在归档模式下。
2、 如果丢失了一个数据文件,或者由于某种原因不能使用特定的数据文件,则不能使用闪回数据库进行恢复。
3、 如果已经在想闪回的时间范围内复原或重建了一个控制文件,则不能使用闪回数据库特性。
4、 不能闪回一个数据库到RESETLOGS操作之前。
def hykdddd
defgdbbea hykdddd
SQL>
注意:回收站中的对象只能进行查询,任何的DML操作将不起作用。
恢复被删除的表
只要回收站中列出被删除的表,就可以使用命令恢复它。
FLASHBACK TABLE table_name TO BEFORE DROP
还有:
清除整个回收站:purge recyclebin
除回收站中的单个表:purge table test_drop
上述命令将从USERS表空间中删除单一用户scott的所有对象(以及存在于其他表空间中的所有依赖对象)。
oracle flash back原理
oracle flash back原理Oracle Flashback是一种数据库恢复和查询技术,它可以基于时间或者特定条件,将数据库恢复到过去的某个状态。
本文将详细介绍Oracle Flashback的原理和实现方式。
现代数据库面临着日益增长的数据量和日志的快速变化。
数据库管理员需要能够在数据损坏或删除时快速恢复数据库,并且能够进行详细的查询和分析操作。
Oracle Flashback技术提供了一种可靠且高效的解决方案,使管理员能够快速恢复数据库,追溯数据变更历史和查询特定时刻的数据状态。
【1. Oracle Flashback的基本原理】Oracle Flashback的原理是通过使用Undo数据和Redo数据来实现数据的恢复和查询。
Undo数据是事务发生前的数据副本,也称为回滚段。
当一个事务发生时,Oracle数据库将当前的数据状态复制一份,称为Undo数据。
在事务执行过程中,所有的修改操作都是在Undo数据上进行的,并且还会保存被修改的数据的一个副本。
这样,当需要恢复到过去的某个时刻时,可通过Undo数据将数据库还原到该时刻的状态。
Redo数据是在数据库中发生修改操作时,记录这些操作的数据。
当数据库发生故障或者需要进行恢复时,通过Redo数据可以将数据库恢复到最近的一次备份或者故障前的状态。
【2. Oracle Flashback的实现方式】Oracle提供了多种方式来实现Flashback技术,包括Flashback Query、Flashback Transaction、Flashback Table、Flashback Database等。
下面分别介绍这些实现方式的原理和使用方法。
(1) Flashback QueryFlashback Query是一种基于时间点查询的技术,可以在一个事务中查询到过去某个时间点的数据库状态。
它通过读取Undo数据和Redo 数据,将数据库恢复到指定时间点的状态,然后执行查询操作。
Oracle闪回查询恢复delete删除数据
SQL> select to_char(sysdate, 'yyyy-mm-dd hh24:mi:ss') time, to_char(dbms_flashback.get_system_change_number) scn from dual;
TIME SCN
1. 不能Falshback到5天以前的数据。
2. 闪回查询无法恢复到表结构改变之前,因为闪回查询使用的是当前的数据字典。
3. 受到undo_retention参数的影响,对于undo_retention之前的数据,Flashback不保证能Flashback成功。
4. 对drop,truncate等不记录回滚的操作,不能恢复。
注:推荐使用scn,由于oracle9i中,因为scn与时间点的同步需要5分钟,如果最近5分钟之内的数据需要Falshback query查询,可能会查询丢失,而scn则不存在这个问题。Oracle10g中这个问题已修正(scn与时间点的大致关系,可以通过logmnr分析归档日志获得)。
Falshback query查询的局限:
SQL> select * from t as of scn 1060174;
3. 将查询到的数据,新增到表中。也可用更直接的方法,如:
SQL>create table tab_test as select * from t of timestamp to_timestamp('2010-06-29 22:57:47', 'yyyy-mm-dd hh24:mi:ss');
Commit complete
4.在查看t表,此时t表中数据以删除
Oracle闪回查询
Oracle闪回查询查找 SCN , Time对应关系: select to_char(sysdate,’yyyy-mm-ddhh24:mi:ss’),to_char(DBMS_FLASHBACK.GET_SYSTEM_CHANGE_NUMBER) AS SCN from dual;通过时间flashback query数据: SELECT * FROM test AS OF TIMESTAMP TO_TIMESTAMP(’2007-04-09 11:25:17′, ‘YYYY-MM-DD HH:MI:SS’);通过SCN 闪回数据: SELECT * FROM test AS OF SCN 23565583;Oracle Flashback Database特性允许通过语句Flashback Database语句,让数据库前滚到当前的前⼀个时间点或者SCN,⽽不需要做时间点的恢复。
闪回数据库可以迅速将数据库回到误操作或⼈为错误的前⼀个时间点,如Word中的"撤消"操作,可以不利⽤就快速的实现基于时间点的恢复。
Oracle通过创建新的Flashback Logs(闪回⽇志),记录数据库的闪回操作。
如果希望能闪回数据库,需要设置如下参数:DB_RECOVER_FILE_DEST⽇志的存放位置, DB_RECOVER_FILE_DEST_SIZE恢复区的⼤⼩。
在创建数据库的时候,Oracle将⾃动创建恢复区,但默认是关闭的,需要执⾏ alter database flashback on命令。
SQL>flashback database to time to_timestamp(xxx);SQL>flashback database to scn xxx ;Oracle Flashback Table特性允许利⽤Flashback Table语句,确保闪回到表的前⼀个时间点。
oracle 数据库闪回查询语句
Oracle数据库提供了闪回查询(Flashback Query)的功能,它允许你查询表在过去某个时间点的数据。
这个功能对于回溯历史数据或者查找误操作引起的数据变更非常有用。
以下是一些 Oracle 数据库中的闪回查询语句的示例:
1. 查询过去某个时间点的数据:
上述语句中,your_table是表的名称,TIMESTAMP后面的字符串表示你希望查询的具体时间点。
2. 查询过去某个 SCN(系统更改号)的数据:
这里的1234567是你希望查询的 SCN 号。
3. 查询在过去一定时间段内的数据变化:
上述语句中,VERSIONS BETWEEN后面的两个时间戳表示你希望查询的时间段内的数据版本。
4. 使用 AS OF SCN 语法查看历史数据:
这个语句允许你在历史版本中进行条件过滤。
请注意,使用闪回查询功能需要相应的权限,而且 Oracle 数据库的
UNDO_RETENTION参数设置也可能对你能够查询的历史时间范围产生影响。
确保在使用这些功能时了解相关的安全和配置考虑。
oracle中闪回语法
在Oracle数据库中,闪回(Flashback)是一种用于恢复数据库到特定时间点的功能。
它允许您撤销数据库更改,并返回到过去的状态。
通过使用闪回语法,您可以轻松地恢复丢失的数据或解决数据不一致问题。
闪回语法的基本格式如下:```scssFLASHBACK table_name TO TIMESTAMP;```其中,`table_name`是要执行闪回操作的表名,`TIMESTAMP`是要返回到的时间戳。
时间戳可以是日期时间值,也可以是系统保留的关键字,如`SYSDATE-1`表示返回到一分钟前的时间状态。
以下是使用闪回语法的一些常见场景和用法:1. 恢复丢失的数据:如果您不小心删除了某个表中的数据,可以使用闪回语法将其恢复到删除之前的状态。
例如:```sqlFLASHBACK table_name TO SYSDATE;```这将返回到表被删除之前的时间状态。
2. 解决数据不一致问题:如果您发现某个表中的数据不一致,可以使用闪回语法将其恢复到一致的状态。
例如,如果您发现某个事务导致数据发生了错误更改,可以使用闪回语法将表返回到事务开始之前的状态。
3. 历史数据查询:如果您需要查询历史数据,可以使用闪回表(Flashback Table)功能。
通过将表设置为闪回表,您可以查询过去的时间戳数据,而无需创建额外的历史表。
4. 数据备份恢复:如果您需要备份数据库并恢复到过去的时间点,可以使用闪回数据库(Flashback Database)功能。
这将整个数据库视为一个单独的逻辑对象,并提供对过去时间和数据点的访问权限。
需要注意的是,使用闪回语法需要满足一些前提条件,例如表必须具有可回滚的物化视图或物化视图刷新日志(MMMF)的约束。
此外,某些表类型(如分区表)可能需要额外的设置才能使用闪回语法。
总之,闪回语法是Oracle数据库中一个非常有用的功能,它可以帮助您轻松地恢复丢失的数据、解决数据不一致问题以及进行历史数据查询。
Oracle Flashback 技术 总结
Oracle Flashback 技术总结Flashback 技术是以Undo segment中的内容为基础的,因此受限于UNDO_RETENTON参数。
要使用flashback 的特性,必须启用自动撤销管理表空间。
在Oracle 10g中,Flash back家族分为以下成员:Flashback Database,Flashback Drop,Flashback Query(分Flashback Query,Flashback V ersion Query,Flashback Transaction Query 三种) 和Flashback Table。
一.Flashback DatabaseFlashback Database 功能非常类似与RMAN的不完全恢复,它可以把整个数据库回退到过去的某个时点的状态,这个功能依赖于Flashback log 日志。
比RMAN更快速和高效。
因此Flashback Database 可以看作是不完全恢复的替代技术。
但它也有某些限制:1. Flashback Database 不能解决Media Failure,这种错误RMAN恢复仍是唯一选择2. 如果删除了数据文件或者利用Shrink技术缩小数据文件大小,这时不能用Flashback Database技术回退到改变之前的状态,这时候就必须先利用RMAN把删除之前或者缩小之前的文件备份restore 出来,然后利用Flashback Database 执行剩下的Flashback Datbase。
3. 如果控制文件是从备份中恢复出来的,或者是重建的控制文件,也不能使用Flashback Database。
4. 使用Flashback Database锁能恢复到的最早的SCN,取决与Flashback Log中记录的最早SCN。
Flashback Database 架构Flashback Database 整个架构包括一个进程Recover Writer(RVWR)后台进程,Flashback Database Log日志和Flash Recovery Area。
oracle数据库执行闪回恢复数据
• archive log list; alter database archivelog;
shutdown immediate • startup mount;
alter database open; alter database open resetlogs; • desc sjh0
闪回数据库: 节省恢复时间
Incomplete Recovery Generate logs
Restore files
• purge table t_user; --从回收站清除。
• show recyclebin; • drop table t_user purge; --彻底删除一个
表,不让进入回收站。 • show recyclebin; --没有对象。
闪回Drop: 注意事项
– 闪回Drop表在以下情形下失效:
Repaired database
Backup
User error
Flashback Database User error
Flashback logs
Apply logs forward
Repaired database
Backup
Apply Flashback logs backward
闪回数据库: 注意事项
闪回表
– 使用闪回表操作, 可以将表恢复到某个时间而不 需要备份资料.
oracle闪回介绍
flashback(闪回)是Oracle10g里新加入的一个非常有用的一个feature。
通过flashback的功能,我们可以避开传统的recover 的方式去恢复一些我们进行的误操作。
不过相当recovery来说。
这两个还是有差别的。
1. recovery的恢复是基于数据文件的,先要restore备份好的数据文件,flashback是基于flashback log文件的,所以基点不一样,recovery是基于备份的时间上的,可以恢复到备份至完整归档的任何一个时刻,而flashback是基于flashback log的,而log的存储时效是受限于db_flashback_retention_target这个参数的(以分钟为单位,默认1440分钟,即24小时)。
2. recovery的恢复是应用redo记录的,所以会对期间我们不关心的数据也进行修补,而flashback可以只针对我们关心的数据进行修补。
3. recovery的恢复可以恢复数据文件物理损坏或者日志物理损坏,而flashback是基于flashback log的,只能处理由于用户的错误的逻辑操作,比如删除了表,删除了用户等。
由此可见,其实flashback和recovery的恢复还是有不少本质的差别的,因此我们要针对着相应的情况来进行相应的选择。
flashback具体来说有4种常用的操作,这几种操作虽然都冠以flashback,但是还是有着一些较大的差别,1、flashback database(闪回数据库)对应flashback database来说,一般用来处理误删除了user或者一些错误的数据操作。
要使用flash database的特性。
我们一定要启动flashback功能,SQL>alter database flashback on; 如果要关闭使用alter database flashback off;同时要配置和检查参数db_flashback_retention_target,这个是控制flashback log的保留时间的参数,默认是1440分钟,即24小时。
oracle flashback用法
oracle flashback用法
Oracle Flashback是一种Oracle数据库提供的功能,用于恢复
或查询数据库的历史数据。
它通过使用数据库中的日志和其他信息来回溯数据库的状态,而不是通过传统的备份和恢复方法。
以下是一些Oracle Flashback的常见用法:
1. Flashback Table:通过Flashback Table命令可以将表还原到
之前的状态。
这个命令可以撤销对表格的一系列更新、删除或插入操作,从而恢复表格的先前状态。
2. Flashback Query:Flashback Query是一种基于时间的查询技术,可以查询数据库在过去某个时间点的数据快照。
通过使用AS OF子句可以指定查询的时间点。
3. Flashback Transaction:Flashback Transaction用于回滚整个
事务,而不仅仅是表格的某个状态。
它会恢复事务在过去的某个时间点的所有更改。
4. Flashback Database:Flashback Database是一种恢复整个数
据库到过去某个时间点的能力。
它可以回滚整个数据库到之前的状态,包括数据文件和控制文件。
需要注意的是,为了使用Oracle Flashback功能,数据库需要
开启Flashback功能,并在数据库中设置合适的Flashback区域。
此外,使用Flashback功能可能对数据库的性能产生一定
影响,因此在使用时需要权衡利弊。
oracle闪回原理
oracle闪回原理Oracle数据库的闪回技术是一种用于快速恢复数据库到某个特定的时间点的技术。
它可以在意外的数据修改、误删除或其他用户错误操作后,快速恢复数据库到以前的状态。
Oracle的闪回技术主要基于redo log和数据文件的架构。
当数据库执行修改操作时,相关的信息会被写入redo log中,而实际的数据则会被写入数据文件。
闪回技术利用了这些日志信息来进行恢复。
具体而言,Oracle 闪回技术通过以下几个步骤实现数据恢复:1. 闪回查询(Flashback Query):利用数据库中的undo表空间和闪回日志文件,可以通过语句查询数据库中某个时间点的数据。
用户可以使用SELECT命令,指定某个时间点进行查询,而不需要进行真正的数据恢复操作。
2. 闪回版本查询(Flashback Version Query):除了对整个数据库进行闪回查询外,还可以对指定表或视图的特定行或列进行查询。
通过查询某个时间点的历史版本,可以找回误删除或修改的数据。
3. 闪回表(Flashback Table):如果需要将整个表恢复到某个时间点,可以使用闪回表功能。
这个功能会对整个表进行快速恢复,而不需要使用传统的恢复方法。
4. 闪回数据库(Flashback Database):对于更大范围的数据恢复,可以使用闪回数据库功能。
这个功能会将整个数据库恢复到某个时间点,并且会自动处理所有相关的数据文件和日志文件。
需要注意的是,闪回技术对于一些操作是有限制的,比如数据文件的删除、表空间的重命名等。
同时,使用闪回技术恢复的数据必须还在系统中,不能超过undo表空间的保留时间。
因此,在实际使用闪回技术前,需要做好相关的配置和规划。
Oracle的闪回特性
Oracle的闪回特性在Oracle 9i之前的版本中,如果用户因为误操作delete或update了数据并最终提交,为了恢复这些用户错误,我们必须通过逻辑备份或者物理备份进行恢复来纠正这些错误,这种方法是极其复杂和低效的。
为了提高数据库的可用性,简化用户的数据恢复,从Oracle 9i开始,Oracle将闪回flashback引入到数据库中,闪回功能类似播放机中的回退功能,通过回退,我们可以找会正确的数据,纠正犯下的错误。
从Oracle 9i到Oracle 10g以及Oracle 11g,Oracle在不停地增加和强化闪回功能,在这一章中,我们将全面介绍Oracle的闪回特性。
1.Oracle 9i的闪回查询特性从Oracle 9i开始Oracle 引入了闪回查询(Flashback Query)的特性,通过闪回查询我们可以按照时间戳或SCN来向前查询,获取修改之前的数据镜像,再通过insert等操作就可以恢复数据。
闪回查询依赖于回滚段中存储的数据前镜像,在Oracle 9i以前的版本中,通常只要事务提交后,前镜像数据就可以被覆盖,空间可以重用;在Oracle 9i中Oracle引入了自动回滚段管理(Automatic Undo Management,简称AUM)的新特性,在AUM模式下,我们可以通过调整undo_retention参数来设置数据库UNDO信息的保留时间,只要前镜像没有被覆盖,那么闪回就是可能的,但是需要注意的是,UNDO信息的保留还同UNDO表空间中的空间有关,如果空间紧张,为了满足事务的需要,非会动的前镜像信息是可以被覆盖的。
可以使用select 语句的as of子句来进行闪回查询,具体语法如下:As of scn/timestamp expr通过关键词as of 可以对表、视图、物化视图进行Flashback Query,可以指定SCN或者timestamp,其中timestamp是9i中引入的新的数据类型,精确到毫秒的时间单位。
Oracle闪回查询
Oracle闪回查询闪回查询(Flashback Query)包括闪回版本查询(Flashback Versions Query)、闪回事务查询(Flashback Transaction Query)和闪回表(Flashback Table)。
回版本查询(Flashback Versions Query)可以查询某条记录在某段时间内的所有版本,并且能够显示一个历史记录,这个历史记录包括对指定记录的操作、进行操作的时间、执行操作的用户以及发生变化的事务标识。
闪回事务查询(Flashback Transaction Query)能够自动化修复过程,一旦使用闪回版本查询(Flashback Versions Query)标识出导致问题的事务,Oracle就可以构造倒退这些变化的SQL。
与Flashback Database不同,Flashback Transaction不好丢失数据,没有出错的工作仍然有效,并且数据库停留在当前的状态。
闪回表(Flashback Table)是针对某个表的出错工作已被提交后,我们可以指定ORACLE倒退从指定的某个时间点以来该表的所进行的所有变化,同时其他表停留在当前的状态。
闪回查询(Flashback Query)操作中,数据库保持打开状态,并且所有对象(包括闪回所涉及的对象)都可用。
事务的完整性与约束会被实施。
闪回查询(Flashback Query)操作中能闪回到哪个时间点依赖于撤销数据。
在 Oracle9i Database 中,我们看到它推出了以闪回查询形式表示的“时间机器”。
该特性允许 DBA 看到特定时间的列值,只要在还原段中提供该数据块此前镜像的拷贝即可。
但是,闪回查询只提供某时刻数据的固定快照,而不是在两个时间点之间被更改数据的运行状态表示。
某些应用程序,如涉及到外币管理的应用程序,可能需要了解一段时期内数值数据的变化,而不仅仅是两个时间点的数值。
由于闪回版本查询特性,Oracle database 10g 能够更方便高效地执行该任务。
oracle 数据库闪回查询语句
oracle 数据库闪回查询语句摘要:1.闪回查询概述2.闪回查询的类型3.闪回查询的语法与示例4.闪回查询的应用场景5.总结正文:1.闪回查询概述Oracle数据库闪回查询语句是Oracle数据库提供的一种非易失性内存(NVM)技术,它允许用户在不影响现有事务的情况下,查询过去的数据状态。
这种技术可以用来查询在某个时间点之前的表数据,或者查询在某个时间点之前已经删除的记录。
闪回查询能够提高数据恢复的速度和准确性,同时减少数据恢复过程中的风险。
2.闪回查询的类型Oracle数据库闪回查询语句主要有以下两种类型:a.闪回查询(Flashback Query)闪回查询用于查询过去的数据状态,可以查询某个时间点之前的表数据,或者查询在某个时间点之前已经删除的记录。
b.闪回事务查询(Flashback Transaction Query)闪回事务查询用于查询在某个事务开始之前或结束之后的表数据。
这种查询可以用来查看事务对表数据的影响,以及回滚事务。
3.闪回查询的语法与示例以下是闪回查询的语法:```SELECT column1, column2, ...FROM table_name AS OF TIMESTAMP TO_TIMESTAMP("2022-01-01 12:00:00", "YYYY-MM-DD HH24:MI:SS")WHERE condition;```示例:```SELECT * FROM employees AS OF TIMESTAMPTO_TIMESTAMP("2021-12-31 11:00:00", "YYYY-MM-DD HH24:MI:SS") WHERE department_id = 100;```该查询将返回在2021年12月31日11:00:00之前的员工记录,且部门ID为100的员工信息。
oracle数据丢失恢复数据方法
oracle数据丢失恢复数据方法在使用Oracle数据库过程中,数据丢失是一种常见的问题。
当数据库中的数据丢失时,我们需要及时采取措施来进行数据恢复,以避免数据的长期丢失。
本文将介绍一些常用的Oracle数据丢失恢复方法,帮助我们有效地处理这个问题。
1. 数据库备份与恢复数据库备份是一种常见的防范措施,它可以帮助我们在数据丢失后快速恢复数据库。
在Oracle中,我们可以使用RMAN(Recovery Manager)工具来实现数据库备份和恢复。
RMAN可以备份整个数据库或者特定的表空间、数据文件等,同时也支持增量备份,大大减少了备份所需的时间和空间。
当数据库发生数据丢失时,我们可以使用RMAN来恢复备份的数据库文件,确保数据的完整性。
2. 闪回技术Oracle提供了闪回技术,可以帮助我们恢复数据库到某个历史时间点的状态。
通过闪回技术,我们可以将数据库中的数据、表结构等回滚到特定的时间点,从而实现数据的恢复。
闪回技术相比于传统的数据恢复方法,具有更高的效率和更少的风险。
我们可以使用闪回查询(FLASHBACK QUERY)来查看历史数据,使用闪回表(FLASHBACK TABLE)来恢复特定表的状态,使用闪回数据库(FLASHBACK DATABASE)来恢复整个数据库。
3. 日志文件恢复Oracle数据库在运行过程中会生成大量的日志文件,这些日志文件记录了数据库的操作、变更等信息。
当数据库发生数据丢失时,我们可以通过日志文件的恢复来还原数据。
在Oracle数据库中,我们可以使用归档日志文件(Archive Log)或在线重做日志文件(Online Redo Log)来进行数据恢复。
归档日志文件可以将数据库中的所有变更操作记录下来,当数据丢失时,我们可以将归档日志文件应用到数据库中,恢复数据的完整性。
同时,我们也可以使用在线重做日志文件来进行数据恢复,将重做日志文件中的操作应用到数据库中。
4. 数据库导入导出数据库导入导出是一种常见的数据恢复方法。
Oracle10g新特性Flashback探究
or c e 72 a l 2 31 1 1 1 3 0 7: 0: 0 7 0 00 om :
r vw r
— —
¥ I - S I
o c rl t aI32 6 ot 0 4
Wre R WR 的新过 程写 入 。 i r( V ) t 这是 O llg的新增 进 程 。 mc O e 我们
FL ASHBACK DAT ABASE LOG; OL DEST FL SHB A ACK SCN OLDEST FL SHBACK TI A
1 6 62 0 03 2 1 01: 42 7 20 5— - 9 0 7: 02
在笔者参与 的一个 大型上市公 司的 E P项 目的开发过程 R
图 2 定 义数 据 对 象
2. 3 初 始 化 2.
中, 使用 S r om 完成特殊格式报表和表单的需求很 大 , mat r f 如何 在 S at r 内部进行 数据 定义并 实现和 R p r程 序 的数据 m rom f eo t 传递 , 一直 困扰着开发 人员 , 本文对 该问题给 出了一个很 好的 解 决办法。
-
与常规 的重做 日志(e o lg ) r o s 不同 , d 回闪 日志既不需 要由 DB A创建 , 也不需要 由他们维护 ; 它们 由 O al Maae i s rc n gd Fl e e
r r… - 1 r ce db 0 2 w-. o a l a 82 01 Mar29 4 9 1 9 6: O1 mf 54b l .b 1 1 cp n
.
( MF) O 自动在 闪回恢复区域所指定的 目录 中创建。 些文件不 这
Oracleg中使用闪回技术详解
Oracle 10g 中使用闪回技术在Oracle10g 中,可以在行、表和数据库级别使用闪回技术,具体分类如下:1、行级闪回可以使用行闪回技术撤销对个别行的错误更改。
在撤销表空间中的撤销数据。
有三种行级闪回技术,他们全都依赖于存储(1)闪回查询:允许根据时间点或SCN(System Change Number)查看旧的行数据。
可以查看更旧的数据,并且,如果需要可以检索它并撤销错误的更改。
(2)闪回版本查询:允许查看相同行在一段时间内的所有版本,以便可撤销逻辑错误。
它还可以提供更改的审计历史,允许比较当前数据与历史数据而不用执行DML 活动。
(3)闪回事务查询:允许查看事务级所做的更改。
此技术帮助分析和审计事务,例如,一个批作业执行了两次,你想确定哪些对象受到影响等。
使用此技术可撤销指定时间段内某个事务所做的更改。
2、表级闪回(1)闪回表:复原一个表到某个时间点,或者到指定的SCN 而不用恢复数据文件。
此特性使用DML 更改撤销表中的更改。
闪回表特性依赖于撤销数据。
(2)闪回删除:允许倒退一条DROP TABLE 语句的结果,而不用进行时间点恢复。
闪回删除特性使用回收站复原被删除的表。
3、数据库级闪回闪回数据库特性允许复原整个数据库到某个时间点,回数据库主要利用闪回日志检索数据块的更旧的版本,据库,不用复原数据文件和执行传统的介质恢复。
从而撤销自该时间以来的所有更改。
闪它也依赖归档重做日志完全地恢复数闪回和传统的恢复技术对比与传统恢复技术不同,闪回技术的主要目的不是从介质丢失中恢复,例如:用户可能错误的删除了某个表或者错误的更改了某个表的数据。
才的操作。
而是从人为错误中恢复。
这时候你想撤销你刚传统上,从人为错误中恢复数据唯一的办法就是采用用户管理的备份和恢复技术。
据库文件然后利用所有重做日志文件前滚的过程需要长时间的停机。
而闪回技术提供了从逻辑错误中恢复的更有效和更快的方法,行恢复时数据库仍然联机并对用户可用。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
Oracle的闪回特性在Oracle 9i之前的版本中,如果用户因为误操作delete或update了数据并最终提交,为了恢复这些用户错误,我们必须通过逻辑备份或者物理备份进行恢复来纠正这些错误,这种方法是极其复杂和低效的。
为了提高数据库的可用性,简化用户的数据恢复,从Oracle 9i开始,Oracle将闪回flashback引入到数据库中,闪回功能类似播放机中的回退功能,通过回退,我们可以找会正确的数据,纠正犯下的错误。
从Oracle 9i到Oracle 10g以及Oracle 11g,Oracle在不停地增加和强化闪回功能,在这一章中,我们将全面介绍Oracle的闪回特性。
1.Oracle 9i的闪回查询特性从Oracle 9i开始Oracle 引入了闪回查询(Flashback Query)的特性,通过闪回查询我们可以按照时间戳或SCN来向前查询,获取修改之前的数据镜像,再通过insert等操作就可以恢复数据。
闪回查询依赖于回滚段中存储的数据前镜像,在Oracle 9i以前的版本中,通常只要事务提交后,前镜像数据就可以被覆盖,空间可以重用;在Oracle 9i中Oracle引入了自动回滚段管理(Automatic Undo Management,简称AUM)的新特性,在AUM模式下,我们可以通过调整undo_retention参数来设置数据库UNDO信息的保留时间,只要前镜像没有被覆盖,那么闪回就是可能的,但是需要注意的是,UNDO信息的保留还同UNDO表空间中的空间有关,如果空间紧张,为了满足事务的需要,非会动的前镜像信息是可以被覆盖的。
可以使用select 语句的as of子句来进行闪回查询,具体语法如下:As of scn/timestamp expr通过关键词as of 可以对表、视图、物化视图进行Flashback Query,可以指定SCN或者timestamp,其中timestamp是9i中引入的新的数据类型,精确到毫秒的时间单位。
2.闪回查询的使用以下通过一个示例来说明如何使用Oracle 的这个新特性。
首先记录一下当前的时间戳,然后删除测试表中的两条数据并提交:SQL> create table test as select * from dba_users;表已创建。
SQL> select count(*) from dba_users;COUNT(*)----------8SQL> select systimestamp from dual;SYSTIMESTAMP---------------------------------------------------------------------------22-3月-11 08.32.38.140000 下午+08:00SQL> delete from test;已删除8行。
SQL> commit;提交完成。
SQL> select count(*) from test;COUNT(*)----------现在可以根据删除的估算时间向前推移查询,通过适当的时间估计,数据可以通过前镜像被很容易的查询回来:SQL> select count(*) from test as of timestamp (systimestamp - interval '60' second);COUNT(*)----------8也可以获得当前的SCN,通过估算,减小SCN向前进行查询尝试,也可以获取删除之前的数据:SQL> select dbms_flashback.get_system_change_number scn from dual;SCN----------897064SQL> select count(*) from test as of scn 897020;COUNT(*)----------8SQL>3.SMON_SCN_TIME与闪回查询在闪回恢复操作中,有一个重要的数据结构起着关键性的作用,这个对象就是SMON_SCN_TIME。
3.1 SMON_SCN_TIMESMON_SCN_TIME是Oracle 10g数据库的系统表,记录一个时间戳和当前的SCN,这个表共保存144000条记录,也就是5天的信息,通过这张表,数据库可以对5天之内的SCN 和时间进行粗略的对应和转换。
这个表被用于进行辅助恢复等功能,闪回查询就依赖于这个系统表,SMON_SCN_TIME 是数据库的一个内部表,Oracle在不同版本中都可能变更这个表的内部和作用。
在Oracle 10g之前,SMON_SCN_TIME由SMON来获取和记录SCN信息的,从Oracle 10g开始,LGWR首先会在SGA中记录SCN与时间的对应关系(由于LGWR至少每3秒就会被激活一次,所以现在smon_scn_time能够支持大于3秒的闪回),SMON则定期检查SGA是否内存中记录的映射大于磁盘的,如果有就刷新记录到磁盘。
看一下Oracle 10g中这个表的结构,从数据库创建脚本sql.bsq文件中可以找到这个对象的创建过程:rem create the scn<->time tracking table that smon will maintainrem as a circular queue - notice that we populate the entirerem table with at least 144000 entries (enough for 5 days).remrem -"thread" is for backward compatibility and is always 0rem -"orig_thread" is for upgrade/downgraderem - scn_wrp, scn_bas, and time_dp are for backward compatibilityrem and not queried by the ktf layer.以上的注释部分说明了这个表的用途,也就是通过这个表构建了scn->time的跟踪关系,而且对于不同的实例,根据thread号进行区分一遍每个实例都能维护一个SCN到时间的映射关系。
以下创建过程首先创建了一个cluster,然后再创建了smon_scn_time表:create cluster smon_scn_to_time (thread number /* thread, compatibility */)/create index smon_scn_to_time_idx on cluster smon_scn_to_time/create table smon_scn_time (thread number, /* thread, compatibility */time_mp number, /* time this recent scn represents */time_dp date, /* time as date, compatibility */scn_wrp number, /* scn.wrp, compatibility */scn_bas number, /* scn.bas, compatibility */num_mappings number,tim_scn_map raw(1200),scn number default 0, /* scn */orig_thread number default 0 /* for downgrade */) cluster smon_scn_to_time (thread)/create unique index smon_scn_time_tim_idx on smon_scn_time(time_mp)/create unique index smon_scn_time_scn_idx on smon_scn_time(scn)/观察一下smon_scn_time中的字段项,其中time_mp代表最新的SCN对应的时间。
在Oracle10g中,这个时间取自系统的内核时间。
Time_dp则代表time_mp转换后的系统时间,这个时间是用户可读的。
Scn_wrp与scn_bas加起来代表SCN,scn_wrp代表SCN的高位,scn_bas代表SCN的低位,我们先来取当前的SCN来验证一下:SQL> select dbms_flashback.get_system_change_number scn from dual;SCN----------899100SQL> select scn_wrp,scn_bas,scn from smon_scn_time where scn=(select max(scn) from smon_scn_time);SCN_WRP SCN_BAS SCN---------- ---------- ----------0 898804 898804这个记录的SCN和获得的系统SCN相差无几,也就是time_mp/time_dp时间数据库对应的SCN。
3.2 SCN_TO_TIMESTAMP与TIMESTAMP_TO_SCNOracle 10g提供了两个新函数对于SCN和时间戳进行相互转换,这两个函数是SCN_TO_TIMESTAMP、TIMESTAMP_TO_SCN,通过对SCN和时间戳进行转换,Oracle 极大地方便了很多备份和恢复过程。
来看一下这两个函数的用法,首先通过的dbms_flashback.get_system_change_number可以获得系统当前的SCN值:SQL> select dbms_flashback.get_system_change_number scn from dual;SCN----------899410SQL> select scn_to_timestamp(899410) timestamp from dual;TIMESTAMP------------------------------------------------------------------22-3月-11 09.39.18.000000000 下午SQL> select timestamp_to_scn(scn_to_timestamp(899410)) timestamp from dual;TIMESTAMP----------899410通过这两个函数,最终Oracle将SCN和时间的关系建立起来,在Oracle 10g之前,是没有办法通过函数转换得到SCN和时间的对应关系的(一般也可以通过logmnr分析日志获得)。