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

Oracle10g数据库中闪回表特性剖析,第1张

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

删除那个表!

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

SQL>select * from tabTNAMETABTYPE CLUSTERID

RECYCLETEST TABLE

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

SQL>drop table recycletestTable dropped

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

SQL>select * from tabTNAME 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 DROPFLASHBACK PLETE SQL>SELECT * FROM TABTNAME 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 ( )mitDROP TABLE TESTCREATE TABLE TEST (COL NUMBER)INSERT INTO TEST VALUES ( )mitDROP TABLE TESTCREATE TABLE TEST (COL NUMBER)INSERT INTO TEST VALUES ( )mitDROP 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

创建目录

mkdir d:\oracle\product\ \database

mkdir e:\oracle\admin\Ora g\bdump

mkdir e:\oracle\admin\Ora g\cdump

mkdir e:\oracle\admin\Ora g\create

mkdir e:\oracle\admin\Ora g\pfile

mkdir e:\oracle\admin\Ora g\udump

mkdir e:\oracle\flash_recovery_area

mkdir e:\oracle\oradata

mkdir e:\oracle\oradata\Ora g

生成windows服务 创建密码文件 在cmd命令下运行

set ORACLE_SID=dbca 绿色部分设置oracle 实例名为 为ora g

d:\oracle\product\ \DB_ \bin\oradim exe new sid ORA G startmode manual spfile d:\oracle\product\ \DB_ \bin\oradim exe edit sid ORA G startmode a spfile

创建一个实例名为dbca 并且有手动启动方式改为自动启动

d:\oracle\product\ \DB_ \bin\orapwd exe file=d:\oracle\product\ \db_ \PWDOra g ora password=sysPassword force=y

用oracle自带的orapwd 为sys用户创建一个默认的密码为sysPassword

执行创建数据库脚本

D:\oracle\ora \bin\sqlplus /nolog @D:\oracle\admin\dbca\scripts\CreateDB sql

D:\oracle\ora \bin\sqlplus /nolog @D:\oracle\admin\dbca\scripts\CreateDBFiles sql

D:\oracle\ora \bin\sqlplus /nolog @D:\oracle\admin\dbca\scripts\CreateDBCatalog sql

D:\oracle\ora \bin\sqlplus /nolog @D:\oracle\admin\dbca\scripts\postDBCreation sql

黑体部分就是创建数据库要调用的脚本

第一 CreateDB sql

connect SYS/change_on_install as SYSDBA 这是刚刚我们设置的密码以sysdba身份连接到数据库

connect SYS/change_on_install as SYSDBA 这是刚刚我们设置的密码以sysdba身份连接到数据库

set echo on

spool D:\oracle\ora \assistants\dbca\logs\CreateDB log 写日志

startup nomount pfile= D:\oracle\admin\dbca\scripts\init ora 调用参数文件 启动数据库到只装载实例阶段

CREATE DATABASE dbca

MAXINSTANCES

MAXLOGHISTORY

MAXLOGFILES

MAXLOGMEMBERS

MAXDATAFILES 控制文件记录的相关最大日志数 日志组 最大数据文件数等限制

DATAFILE D:\oracle\oradata\dbca\system dbf SIZE M REUSE AUTOEXTEND ON NEXT K MAXSIZE UNLIMITED

EXTENT MANAGEMENT LOCAL

DEFAULT TEMPORARY TABLESPACE TEMP TEMPFILE D:\oracle\oradata\dbca\temp dbf SIZE M REUSE AUTOEXTEND ON NEXT K MAXSIZE UNLIMITED

UNDO TABLESPACE UNDOTBS DATAFILE D:\oracle\oradata\dbca\undotbs dbf SIZE M REUSE AUTOEXTEND ON NEXT K MAXSIZE UNLIMITED 创建系统 临时 回滚 表空间ITPUB个人空间!dJ l {!i W r f

CHARACTER SET ZHS GBK

NATIONAL CHARACTER SET AL UTF 字符集

LOGFILE GROUP ( D:\oracle\oradata\dbca\redo log ) SIZE K

GROUP ( D:\oracle\oradata\dbca\redo log ) SIZE K

GROUP ( D:\oracle\oradata\dbca\redo log ) SIZE K创建日志文件租和成员

spool off

exit

第二 CreateDBFiles sql

connect SYS/change_on_install as SYSDBA

set echo on

spool D:\oracle\ora \assistants\dbca\logs\CreateDBFiles log

CREATE TABLESPACE INDX LOGGING DATAFILE D:\oracle\oradata\dbca\indx dbf SIZE M REUSE AUTOEXTEND ON NEXT K MAXSIZE UNLIMITED EXTENT MANAGEMENT LOCAL SEGMENT SPACE MANAGEMENT AUTO

CREATE TABLESPACE TOOLS LOGGING DATAFILE D:\oracle\oradata\dbca\tools dbf SIZE M REUSE AUTOEXTEND ON NEXT K MAXSIZE UNLIMITED EXTENT MANAGEMENT LOCAL SEGMENT SPACE MANAGEMENT AUTO

CREATE TABLESPACE USERS LOGGING DATAFILE D:\oracle\oradata\dbca\users dbf SIZE M REUSE AUTOEXTEND ON NEXT K MAXSIZE UNLIMITED EXTENT MANAGEMENT LOCAL SEGMENT SPACE MANAGEMENT AUTO 创建相关用户要用到的表空间

spool off

第三:CreateDBCatalog sql

创建system数据字典 存放到system表空间 相关表 视图等

connect SYS/change_on_install as SYSDBA

set echo on

spool D:\oracle\ora \assistants\dbca\logs\CreateDBCatalog log

@D:\oracle\ora \rdbms\admin\catalog sql

@D:\oracle\ora \rdbms\admin\catexp sql

@D:\oracle\ora \rdbms\admin\catblock sql

@D:\oracle\ora \rdbms\admin\catproc sql

@D:\oracle\ora \rdbms\admin\catoctk sql

@D:\oracle\ora \rdbms\admin\owminst plb

connect SYSTEM/manager

@D:\oracle\ora \sqlplus\admin\pupbld sql

connect SYSTEM/manager

set echo on

spool D:\oracle\ora \assistants\dbca\logs\sqlPlusHelp log

@D:\oracle\ora \sqlplus\admin\help\hlpbld sql helpus sql

spool off

spool off

exit

第四: postDBCreation sql

connect SYS/change_on_install as SYSDBA

set echo on

spool D:\oracle\ora \assistants\dbca\logs\postDBCreation log

@D:\oracle\ora \rdbms\admin\utlrp sql编译相关视图 包对象等

shutdown 关闭数据库

connect SYS/change_on_install as SYSDBA

set echo on

spool D:\oracle\ora \assistants\dbca\logs\postDBCreation log

create spfile= D:\oracle\ora \database\spfiledbca ora FROM pfile= D:\oracle\admin\dbca\scripts\init ora

创建服务器参数文件代替文件初始化参数文件 方便有时在不重启数据库的情况下可以使参数生效

从上面可以看到spfile文件的存放位置

startup 启动数据库 创建数据库完成 从上面可以看出 创建数据库有以下 个步骤

Step : 创建相关trace目录文件夹

Step :创建实例 密码 启动方式

Step :创建初始化参数文件 init ora

Step : 连接到实例

Step : 启动实例到nomount状态

Step :创建数据库

Step :创建表空间

Step : 运行脚本创建数据字典

Step : 创建服务器参数文件(这步不是必须的 但oracle建议做这步) 好处会在以后的总结中列出

下面也贴出linux下脚本 和windows下几乎差不多

#!/bin/sh

mkdir /oradata/ora i

mkdir /oradata/ora i/controlfile

mkdir /oradata/ora i/redofile

mkdir /orasys/oracle/admin

mkdir /orasys/oracle/admin/ora i

mkdir /orasys/oracle/admin/ora i/bdump

mkdir /orasys/oracle/admin/ora i/cdump

mkdir /orasys/oracle/admin/ora i/create

mkdir /orasys/oracle/admin/ora i/udump

mkdir /orasys/oracle/admin/ora i/pfile

cp init ora /orasys/oracle/product/ /dbs/

export ORACLE_BASE=/orasys/oracle

export ORACLE_HOME=$ORACLE_BASE/product/

export ORACLE_SID=ora i

export ORA_NLS =$ORACLE_HOME/omon/nls/admin/data

LD_LIBRARY_PATH=$ORACLE_HOME/lib:/lib:/usr/lib

LD_LIBRARY_PATH=$LD_LIBRARY_PATH:/usr/local/lib

export LD_LIBRARY_PATH

export PATH=$PATH:$ORACLE_HOME/bin

echo Add this entry in the oratab: ora i:/orasys/oracle/product/ :Y

/orasys/oracle/product/ /bin/orapwd file=/orasys/oracle/product/ /dbs/orapwora i password=change_on_install

/orasys/oracle/product/ /bin/sqlplus /nolog @/home/oracle/create_script/CreateDB sql

/orasys/oracle/product/ /bin/sqlplus /nolog @/home/oracle/create_script/CreateDBFiles sql

/orasys/oracle/product/ /bin/sqlplus /nolog @/home/oracle/create_script/CreateDBCatalog sql

lishixinzhi/Article/program/Oracle/201311/17648


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

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

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

发表评论

登录后才能评论

评论列表(0条)

保存