Oracle10g数据库中闪回表特性剖析

作者&投稿:殳怜 (若有异议请与网页底部的电邮联系)
~

  Oracle i Database 推出了闪回查询选项的概念 以便检索过去某个时间点的数据 但它不能闪回 DDL 操作 如删除表的操作 唯一的恢复方法是在另一个数据库中使用表空间的时间点恢复 然后使用导出/导入或其他方法 在当前数据库中重新创建表 这一过程需要 DBA 进行大量工作并且耗费宝贵的时间 更不用说还要使用另一个数据库进行克隆 使用 Oracle Database g 中的闪回表特性 它使得被删除表的恢复过程如同执行几条语句一样简单 让我们来看该特性是如何工作的

  删除那个表!

  首先 让我们查看当前模式中的表

  

  

  SQL> select * from tab;TNAMETABTYPE CLUSTERID

   RECYCLETEST TABLE

  现在 我们意外地删除了该表

  

  

  SQL> drop table recycletest;Table dropped

    现在让我们来查看该表的状态

  

  

  SQL> select * from tab;TNAME TABTYPE CLUSTERID BIN$ LhcpndanfgMAAAAAANPw==$ TABLE

  表RECYCLETEST 已不存在 但是请注意出现新表BIN$ LhcpndanfgMAAAAAANPw==$ 这就是所发生的事情 被删除的表 RECYCLETEST 并没有完全消失 而是重命名为一个由系统定义的名称 它存在于同一个表空间中 具有与原始表相同的结构 如果在该表上定义了索引或触发器 则它们也被重命名 使用与表相同的命名规则 任何相关源(如过程)都失效 原始表的触发器和索引被改为放置在重命名的表 BIN$ LhcpndanfgMAAAAAANPw==$ 上 保持被删除表的完整对象结构

  表及其相关对象被放置在一个称为 回收站 的逻辑容器中 它类似于您 PC 机中的回收站 但是 对象并没有从它们原先所在的表空间中删除 它们仍然占用那里的空间 回收站只是一个列出被删除对象目录的逻辑结构 在 SQL*Plus 提示符处使用以下命令来查看其内容(您需要使用 SQL*Plus 来进行此操作)

  

  

  SQL> show recyclebinORIGINAL NAME RECYCLEBIN NAMEOBJECT TYPE DROP TIME RECYCLETESTBIN$ LhcpndanfgMAAAAAANPw==$ TABLE : : :

  结果显示了表的原始名称 RECYCLETEST 并显示了回收站中的新名称 该名称与我们看到的删除后所创建的新表名称相同 (注意 确切的名称可能因平台不同而不同 )为恢复该表 您所需要做的就是使用 FLASHBACK TABLE 命令

  

  

  SQL> FLASHBACK TABLE RECYCLETEST TO BEFORE DROP;FLASHBACK PLETE SQL> SELECT * FROM TAB;TNAME TABTYPE CLUSTERID RECYCLETESTTABLE

  瞧!表毫不费力地恢复了 如果现在查看回收站 它将是空的 记住 将表放在回收站里并不在原始表空间中释放空间 要释放空间 您需要使用以下命令清空回收站

  

  

  PURGE RECYCLEBIN;

  但是如果您希望完全删除该表而不需要使用闪回特性 该怎么办?在这种情况下 可以使用以下命令永久删除该表

  

  

  DROP TABLE RECYCLETEST PURGE;

  此命令不会将表重命名为回收站中的名称 而是永久删除该表 就象 g 之前的版本一样

  管理回收站

  如果在该过程中没有实际删除表 — 因而没有释放表空间 — 那么当被删除的对象占用了所有空间时 会发生什么事?

  答案很简单 这种情况根本不会出现 当表空间被回收站数据完全占满 以至于必须扩展数据文件来容纳更多数据时 可以说表空间处于 空间压力 情况下 此时 对象以先进先出的方式从回收站中自动清除 在删除表之前 相关对象(如索引)被删除

  同样 空间压力可能由特定表空间定义的用户限额而引起 表空间可能有足够的空余空间 但用户可能将其在该表空间中所分配的部分用完了 在这种情况下 Oracle 自动清除该表空间中属于该用户的对象

  此外 有几种方法可以手动控制回收站 如果在删除名为 TEST 的特定表之后需要从回收站中清除它 可以执行

  

  

  PURGE TABLE TEST;

  或者使用其回收站中的名称

  

  

  PURGE TABLE BIN$ LhcpndanfgMAAAAAANPw==$ ;

  此命令将从回收站中删除表 TEST 及所有相关对象 如索引 约束等 从而节省了空间 但是 如果要从回收站中永久删除索引 则可以使用以下命令来完成工作

  

  

  purge index in_test _ ;

  此命令将仅仅删除索引 而将表的拷贝留在回收站中 有时在更高级别上进行清除可能会有用 例如 您可能希望清除表空间 USERS 的回收站中的所有对象 可以执行

  

  

  PURGE TABLESPACE USERS;

    您也许希望只为该表空间中特定用户清空回收站 在数据仓库类型的环境中 用户创建和删除许多临时表 此时这种方法可能会有用 您可以更改上述命令 限定只清除特定的用户

  

  

  PURGE TABLESPACE USERS USER SCOTT;

  诸如 SCOTT 等用户可以使用以下命令来清空自己的回收站

  

  

  PURGE RECYCLEBIN;

  DBA 可以使用以下命令清除任何表空间中的所有对象

  

  

  PURGE DBA_RECYCLEBIN;

  可以看到 可以通过多种不同方法来管理回收站 以满足特定的需要

  表版本和闪回功能

  用户可能会经常多次创建和删除同一个表 如

  

  

  CREATE TABLE TEST (COL NUMBER);INSERT INTO TEST VALUES ( );mit;DROP TABLE TEST;CREATE TABLE TEST (COL NUMBER);INSERT INTO TEST VALUES ( );mit;DROP TABLE TEST;CREATE TABLE TEST (COL NUMBER);INSERT INTO TEST VALUES ( );mit;DROP TABLE TEST;

  此时 如果您要对表 TEST 执行闪回操作 那么列 COL 的值应该是什么?常规想法可能认为从回收站取回表的第一个版本 列 COL 的值是 实际上 取回的是表的第三个版本 而不是第一个 因此列 COL 的值为 而不是

  此时您还可以取回被删除表的其他版本 但是 表 TEST 的存在不允许出现这种情况 您有两种选择

  使用重命名选项

  

  

  FLASHBACK TABLE TEST TO BEFORE DROP RENAME TO TEST ;FLASHBACK TABLE TEST TO BEFORE DROP RENAME TO TEST ;

  这些语句将表的第一个版本恢复到 TEST 将第二个版本恢复到 TEST TEST 和 TEST 中的列 COL 的值将分别是 和 或者 使用表的特定回收站名称进行恢复 为此 首先要识别表的回收站名称 然后执行

  

  

  FLASHBACK TABLE BIN$ LhcpnoanfgMAAAAAANPw==$ TO BEFORE DROP RENAME TO TEST ;FLASHBACK TABLE BIN$ LhcpnqanfgMAAAAAANPw==$ TO BEFORE DROP RENAME TO TEST ;

  这些语句将恢复被删除表的两个版本

  警告

  取消删除特性使表恢复其原始名称 但是索引和触发器等相关对象并没有恢复原始名称 它们仍然使用回收站的名称 在表上定义的源(如视图和过程)没有重新编译 仍然保持无效状态 必须手动得到这些原有名称并应用到闪回表

  信息保留在名为 USER_RECYCLEBIN 的视图中 在对表进行闪回操作前 请使用以下查询来检索原有名称

  

  

  SELECT OBJECT_NAME ORIGINAL_NAME TYPEFROM USER_RECYCLEBINWHERE BASE_OBJECT = (SELECT BASE_OBJECT FROM USER_RECYCLEBINWHERE ORIGINAL_NAME = RECYCLETEST )AND ORIGINAL_NAME != RECYCLETEST ;

  OBJECT_NAMEORIGINAL_N TYPE BIN$ LhcpnianfgMAAAAAANPw==$ IN_RT_   INDEXBIN$ LhcpnganfgMAAAAAANPw==$ TR_RT TRIGGER

  在表进行闪回操作后 表 RECYCLETEST 上的索引和触发器将按照 OBJECT_NAME 列中所示进行命名 根据以上查询 可以使用原始名称重新命名对象 如下所示

  

  

  ALTER INDEX BIN$ LhcpnianfgMAAAAAANPw==$ RENAME TO IN_RT_ ;ALTER TRIGGER BIN$ LhcpnganfgMAAAAAANPw==$ RENAME TO TR_RT;

lishixinzhi/Article/program/Oracle/201311/17794




苦求一个ARACLE10G安装的数据库合法口令!!!
没明白你说的意思,安装的数据库口令是你自己设置的,指定数据库方案的口令。包括SYS、SYSTEM、SYSMAN、DBSNMP的口令。注意口令的首字符为字母。如果安装了你忘记了口令你用 c:>sqlplus "\/ as sysdba"试试 以匿名DBA身份登陆,当然这个只限于在服务器本机上,客户机这样不好用 sql>alter user sys identif...

我安装oracle10g 不知道怎么打开oracle数据库\/
哦,是这样的,oracle就是多了一个用户的概念,一个链接的概念,他们的之间的关系好像是m:n 不过你们说的oracle 11以前的版本,11g 有个racle 11g sqldeveloper 这个可视 的 sql软件 配置 打开sqldeveloper——》Connections——》右键Connections——》弹出New \/ Select Database Connection Connection Na...

求教mac lion 10.7.2 如何安装oracle 10g?
确实,网上的帖子都是基于雪豹来安装的,狮子很少有安装成功的。现在的最新版本是10.9大浪,苹果在这一版本的系统做了很大的改动,已经基本不能安装oracle了,无论是10g for mac,还是11g for linux我都用各种办法尝试过了,都不行,只能等甲骨文官方放出更新了。但是,现在的情况是,苹果在今年秋天还...

西北地区基于3S技术野外地质工作管理与服务体系构建
软件资源:O racle10g或以上版本O racle客户端\/服务器、GSIGrid野外地质调查管理服务与安全保障系统-信息平台 BDServer、北斗应急保障系统站点配置工具MVEConfigGuide。 3.北斗应急态势保障系统运行情况 北斗应急态势保障系统部署完成后,课题组人员对系统的各项功能进行了测试与示范。系统运行正常,以下为部分功能使用截图。图...

oracle spatial 最新版本 支持分布式吗
ORACLE SPATIAL从1995年ORACLE 7.1.6开始发展到2003年的10G版本,空间数据处理能力越来越强大。ORACLE SPATIAL将所有的地理空间数据类型(矢量、栅格、网格、影像、网络、拓扑)统一在单一、开放的、基于标准的数据管理环境中,这就减少了管理单独、分离的专用系统的成本、复杂性和开销。RACLE SPATIAL不但具有...

高手进,VS2010连不上Oracle数据库,怎么回事?
主要是因为64位win7系统的Program Files (x86)路径中的括号引起的,oracle不认识这样的路径,所以就出现不能连接数据库了。解决方法:1、在win7 64位下,先安装Oracle 11g客户端,可以在oracle官网去下载。2、安装好后,将oracle10g的network中的文件全部拷贝到Oracle 11g目录下的network文件夹下.路径例如...

宣威市14774715151: 如何彻底的删除Oracle表 及 闪回恢复在回收站里的数据 -
寇郑莱亿: 不能回滚,也不会记录到redo中,10g以后如果启动了flashback, drop 语句删除的表可以从回收站找回来,truncate语句则没有办法,只能使用数据库闪回或者从有效备份当中进行恢复.

宣威市14774715151: oracle 10g 中执行了 delete from emp; 请问怎样将数据表内容恢复? -
寇郑莱亿: 第一步,获得当前scn select dbms_flashback.get_system_change_number from dual; 第二步,根据第三步返回的scn不停地尝试查询直到所有记录都存在为止. select count(*) from t1 as of scn 10670000;--10670000为返回的scn 第三步,当第...

宣威市14774715151: oracle 单张表恢复问题
寇郑莱亿: 假如你的数据库没有关闭回收站.那么可以根据10g的新特性进行单表闪回恢复. 下面例子如下 SQL> create table test as select * from tab; 表已创建. SQL> drop table test; 表已删除. SQL> show recyclebin; ORIGINAL NAME RECYCLEBIN ...

宣威市14774715151: oracle的flashback怎么用 -
寇郑莱亿: flashback database要求数据库必须处于归档模式,且闪回之后必须使用resetlogs打开数据库 查看数据库的归档模式及闪回是否启用 SQL> select log_mode,open_mode,flashback_on from v$database; LOG_MODE OPEN_MODE FLASHBACK_ON ------------ --...

宣威市14774715151: 高手指点oracle闪回表有哪些限制?
寇郑莱亿: 用百度能搜大把出来吧....使用的限制和注意事项:1. 使用闪回表语句恢复表到出现人为或应用错误事件之前的状态.2. 可以闪回到过去多长时间取决于系统中undo数据量的大小.3. 并且oracle数据库无法恢复通过DDL语句修改了结构的表...

宣威市14774715151: 误删除了delete oracle中数据表记录,没备份要怎么恢复 -
寇郑莱亿: 利用oracle提供的闪回方法,如果在删除数据后还没做大量的操作(只要保证被删除数据的块没被覆写),就可以利用闪回方式直接找回删除的数据 具体步骤为: *确定删除数据的时间(在删除数据之前的时间就行,不过最好是删除数据的时间...

宣威市14774715151: oracle数据库表如何恢复到特定时间点? -
寇郑莱亿: 如果开启闪回可以使用闪回表. select log_mode,flashback_on from v$database; 如果是下面结果则开了闪回 LOG_MODE FLASHBACK_ON ------------ ------------------ ARCHIVELOG YES 可以执行以下命令 alter table 表名 enable row movement;...

宣威市14774715151: 怎么能还原ORACLE在某个时间点的表数据,数据库是ORACLE 10G,操作是新增,但是数据找不到想把数据删除掉 -
寇郑莱亿: 方法很多,要看实际情况:1、若那个时间点后的数据不是必需的,可根据备份文件和归档日志恢复到该时间点.2、若开了闪回,可直接用flashback,闪回表到该时间点.3、若以上都不行,可根据归档日志,用logminer工具找到那个时间点的数据,再插入到相关表中.

宣威市14774715151: 闪回区的路径是什么 oracle -
寇郑莱亿: 在sqlplus中查询db_recovery_file_dest参数 show parameter db_recovery_file_dest

宣威市14774715151: 求教Oracle11g中的闪回技术 -
寇郑莱亿: 1、Flashback Database(利用闪回日志恢复) Oracle Flashback Database特性允许通过SQL语句Flashback Database语句,让数据库前滚到当前的前一个时间点或者SCN,而不需要做时间点的恢复.闪回数据库可以迅速将数据库回到误操作...

本站内容来自于网友发表,不代表本站立场,仅表示其个人看法,不对其真实性、正确性、有效性作任何的担保
相关事宜请发邮件给我们
© 星空见康网