oracle闪回
- 格式:docx
- 大小:19.37 KB
- 文档页数:4
oracle中闪回语法全文共四篇示例,供读者参考第一篇示例:Oracle中的闪回功能是一种强大的特性,它可以让用户在数据库操作出现错误时快速恢复数据到之前的状态。
通过使用闪回功能,用户可以在不影响其他正在运行的事务的情况下,进行数据的回滚操作,使数据库恢复到之前一个确定的时间点。
在Oracle中,闪回功能主要通过闪回查询和闪回表来实现。
闪回查询可以让用户查看数据库在某个时间点的数据情况,而闪回表可以让用户将表恢复到之前的状态。
下面我们来详细介绍一下这两种闪回功能的具体语法和用法。
闪回查询的语法如下:```SELECT * FROM table_name AS OF TIMESTAMP timestamp;```这条SQL语句表示从指定的时间戳timestamp时刻查看table_name表的数据情况。
用户可以使用这种方式来查看数据库在某个具体时刻的数据,从而找出误操作的原因,或者进行数据对比和分析。
除了基本的闪回查询和闪回表功能之外,Oracle中还提供了其他一些灵活的闪回功能,比如闪回查询带条件、闪回表到某个SCN号、闪回事务等。
用户可以根据具体的需求和情况,选择合适的闪回方式进行操作。
需要注意的是,闪回功能在数据库恢复和数据修复方面有着非常重要的作用,但在使用时也需要谨慎操作,以避免对数据造成更大的影响。
在使用闪回功能之前,用户最好提前做好数据备份和日志记录,以防止操作出现意外情况。
Oracle中的闪回功能是一项非常实用和强大的特性,它可以帮助用户在数据库操作出现错误时快速恢复数据,有效避免数据丢失和影响。
通过灵活运用闪回功能,可以提高数据库的稳定性和安全性,保证数据的完整和可靠性。
希望本文的介绍能够对大家有所帮助,希望大家在使用Oracle数据库时,能够充分利用闪回功能,提升数据管理的效率和水平。
第二篇示例: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数据库提供了闪回查询(Flashback Query)的功能,它允许你查询表在过去某个时间点的数据。
这个功能对于回溯历史数据或者查找误操作引起的数据变更非常有用。
以下是一些 Oracle 数据库中的闪回查询语句的示例:
1. 查询过去某个时间点的数据:
上述语句中,your_table是表的名称,TIMESTAMP后面的字符串表示你希望查询的具体时间点。
2. 查询过去某个 SCN(系统更改号)的数据:
这里的1234567是你希望查询的 SCN 号。
3. 查询在过去一定时间段内的数据变化:
上述语句中,VERSIONS BETWEEN后面的两个时间戳表示你希望查询的时间段内的数据版本。
4. 使用 AS OF SCN 语法查看历史数据:
这个语句允许你在历史版本中进行条件过滤。
请注意,使用闪回查询功能需要相应的权限,而且 Oracle 数据库的
UNDO_RETENTION参数设置也可能对你能够查询的历史时间范围产生影响。
确保在使用这些功能时了解相关的安全和配置考虑。
解决oracle闪回区存储空间耗尽问题的方法
解决Oracle闪回区存储空间耗尽问题的方法如下:
1.通过增加闪回区的存储空间来解决空间耗尽的问题。
可以通过以
下步骤来完成:ALTER DATABASE FLASHBACK ON、ALTER SYSTEM SET DB_RECOVERY_FILE_DEST_SIZE=[G|M]1。
2.把数据库启动到mount状态并把闪回空间改大。
可以通过以下步
骤来完成:SQL>startup mount、SQL>alter system set db_recovery_file_dest_size=10G scope=both、SQL>alter database open。
3.用RMAN命令删除老的日志文件。
可以通过以下步骤来完成:操
作系统命令,删除物理文件(rm -vf ) 进入rman、RMAN>crosscheck archivelog all、RMAN>delete expired archivelog all、SQL>select (space_used/space_limit)*100 from v$recovery_file_dest; 查看闪回空间使用率查看alert告警,以及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数据库中一个非常有用的功能,它可以帮助您轻松地恢复丢失的数据、解决数据不一致问题以及进行历史数据查询。
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小时。
闪回基本参数
企业版才支持数据闪回
打开重置日志ALTER DATABASE OPEN RESETLOGS
必须在归档模式archive log list;
开启mount状态startup mount exclusive;
查看闪回参数show parameter db_recovery
show parameter flashback
设置闪回空间alter system set db_recovery_file_dest='/u01/app/oracle/flashback_area' scope=spfile; 设置闪回区大小alter system set db_recovery_file_dest_size=20g scope=spfile;
设置保留时间
alter system set db_flashback_retention_target=4320;
开启闪回alter database flashback on;
查看闪回开启select flashback_on from v$database;
具体闪回待添加----搭建rac之后
创建可靠还原点
sys@WZXIS>create restore point b1 guarantee flashback database;
闪回表
scott@DJJXIS>drop table emp;
Table dropped.
scott@DJJXIS>select * from tab;
TNAME TABTYPE CLUSTERID
------------------------------ ------- ----------
BIN$R+Kc8tW4kBTgVQAAAAAAAQ==$0 TABLE
BONUS TABLE
DEPT TABLE
SALGRADE TABLE
查看回收站
scott@DJJXIS>show recyclebin;
ORIGINAL NAME RECYCLEBIN NAME OBJECT TYPE DROP TIME
---------------- ------------------------------ ------------ -------- EMP BIN$R+Kc8tW4kBTgVQAAAAAAAQ==$0 TABLE 2017-02-07:03:31:11
scott@DJJXIS>flashback table emp to before drop;
Flashback complete.
彻底删除表:purge选项
scott@DJJXIS>drop table T purge;
Table dropped.
scott@DJJXIS>select * from tab;
TNAME TABTYPE CLUSTERID
------------------------------ ------- ----------
BIN$R+Kc8tW4kBTgVQAAAAAAAQ==$0 TABLE
BONUS TABLE
DEPT TABLE
SALGRADE TABLE
闪回查询
这个可能用EM来做更加方便
闪回删除表
标记时间点
sys@WZXIS>select sysdate from dual;
SYSDATE
-------------------
2017-01-31 10:21:48
sys@WZXIS>shutdown immediate
sys@WZXIS>flashback database to timestamp to_timestamp('2017-01-31 09:48:48','yyyy-mm-dd hh24:mi:ss');
sys@WZXIS>alter database open read only;
sys@WZXIS>select * from scott.emp;没有发现
sys@WZXIS>startup force mount
.......一直到找到emp表
找到之后另起会话
[oracle@localhost ~]$ exp scott/tiger file=/backup/emp.dump tables=emp [oracle@localhost ~]$ imp scott/tiger file=/backup/emp.dump tables=emp
sys@WZXIS>flashback database to timestamp to_timestamp('2017-01-31 10:21:48','yyyy-mm-dd hh24:mi:ss');
sys@WZXIS>alter database open resetlogs;
可靠还原点
不受闪回区时间的限制,都能还原到这个点,一般用作测试数据库,
创建:
sys@WZXIS>create restore point b3 guarantee flashback database; Restore point created.
闪回可靠还原点:
sys@WZXIS>flashback database to restore point b3;
Flashback complete.
sys@WZXIS>alter database open resetlogs;
Database altered.
查询已建立的还原点
sys@WZXIS>select name from v$restore_point;
NAME
------------------------------
B1
删除还原点
sys@WZXIS>drop restore point b1;
Restore point dropped.。