关闭

Oracle的闪回

675人阅读 评论(0) 收藏 举报
Oracle的闪回
	oracle中为什么会有闪回呢!它的作用是什么呢?我们来学习一下闪回吧!闪回和回滚异曲同工之妙。
一   闪回的介绍
(1)在Oracle的操作工程中,会不可避免地出现操作失误或者用户失误,例如不小心删除了一个表等,这些失误和错误可能会造成重要数据的丢失,最终导致Oracle数据库停止允许。
(2)在传统意义上,当发生数据丢失、数据错误问题时,解决的主要办法是数据的导入导出、备份恢复技术,这些方法都需要在发生错误前,有一个正确的备份才能进行恢复。
(3)为了减少这方面的损失,Oracle提供了闪回技术。有了闪回技术,就可以实现数据的快速恢复,而且不需要数据备份。
	有了闪回,那他的优点是什么呢?
(1)恢复中,闪回技术是革命性的进步
(2)传统的恢复技术缓慢:
它是整个数据库或者一个文件恢复,不只恢复损坏的数据
在数据库日志中每个修改都必须被检查
(3)闪回速度快:
通过行和事务把改变编入索引
仅仅改变了的数据会被恢复
(4)闪回命令很容易:
没有复杂棘手的多步程序
	闪回的类型:
	闪回表(flashback table)、闪回删除(flashback drop)、闪回版本查询(flashback version query)、闪回事务查询(flashback transaction query)
闪回的益处
(1)恢复中,闪回技术是革命性的进步
(2)传统的恢复技术缓慢:
•	它是整个数据库或者一个文件恢复,不只恢复损坏的数据
•	在数据库日志中每个修改都必须被检查
(3)闪回速度快:
•	通过行和事务把改变编入索引
•	仅仅改变了的数据会被恢复
(4)闪回命令很容易:
•	没有复杂棘手的多步程序

二   闪回表的使用
1.闪回表
闪回表,实际上是将表中的数据快速恢复到过去的一个是焦点或者系统改变号SCN上。实现表的闪回,需要使用到与撤销表空间相关的undo信息,通过show parameter undo命令可以了解这些信息。

用户对表数据的修改操作,都记录在撤销表空间中,这为表的闪回提供了数据恢复的基础。例如,某个修改操作在提交后被记录在撤销表空间中,保留时间为900秒,用户可以在这900秒的时间内对表进行闪回操作,从而将表中的数据恢复到修改之前的状态。
执行表的闪回,需要有flashback any table的权限
2.举例
(1)查询闪回信息
SQL> show parameter undo;
NAME                                 TYPE        VALUE
------------------------------------ ----------- ------------------------------
undo_management                      string      AUTO
undo_retention                       integer     900
undo_tablespace                      string      UNDOTBS1

(2)修改闪回信息
	在修改时首先要切换用户,为conn system/orcl,然后再修改为:
SQL> alter system set undo_retention=1200 scope=both;
System altered
(3)在修改密码的时候要先打开比表的行移动开关
打开行移动开关
	SQL> alter table flashbacktable enable row movement;
Table altered
(4)闪回的应用
	通过temestamp闪回
	首先要先创建表来存储数据:
SQL> create table flashbacktable(id number,ename varchar2(20));
Table created
	然后向其中插入数据
	SQL> insert into flashbacktable values(5,'sdf');
1 row inserted
commit;
SQL> select to_char(sysdate,'yyyy-mm-dd hh24:mi:ss') from dual;
TO_CHAR(SYSDATE,'YYYY-MM-DDHH2
------------------------------
2012-03-23 15:24:53
SQL> flashback table flashbacktable to timestamp to_date('2012-03-23 15:24:53','yyyy-mm-dd hh24:mi:ss');
Done
在查询数据的时候刚才插入的数据没有了,注意是在提交之后执行的闪回

通过scn号闪回
首先查询出当前日期的scn号
SQL> select timestamp_to_scn(sysdate) from dual; 
TIMESTAMP_TO_SCN(SYSDATE)
-------------------------
                  1335034

然后向表中插入数据
SQL> insert into flashbacktable values(12,'dfds');
1 row inserted
SQL> insert into flashbacktable values(13,'dfds');
1 row inserted

SQL> select timestamp_to_scn(sysdate) from dual;
TIMESTAMP_TO_SCN(SYSDATE)
-------------------------
                  1335053

SQL> update flashbacktable set ename='aaaaaaaaaa' where id=12;
1 row updated

SQL> select timestamp_to_scn(sysdate) from dual;
TIMESTAMP_TO_SCN(SYSDATE)
-------------------------
                  1335088

因为有三个阶段的scn,所以可以指定那个scn来闪回
执行的语句为:
SQL> flashback table flashbacktable to scn(1335053);
Done

三  闪回删除
闪回删除,实际上从系统的回收站中将已删除的对象,恢复到删除之前的状态。
系统的回收站只对普通用户有作用
1.	闪回表删除的介绍
(1)回收站是所有被删除对象及其相依对象的逻辑存储容器,例如当一个表被删除(drop)时,该表及其相依对象并不会马上被数据库彻底删除,而是被保存到回收站中。
(2)回收站将用户执行的drop操作记录在一个系统表中,也就是将被删除的对象写到一个数据字典中。如果确定不再需要该对象,可以使用purge命令对回收站进行清空。
(3)被删除的对象的名字可能是相同的,例如用户创建了一个test表,使用drop命令删除该表后,又创建了一个test表,这时,如果再次删除该表就会导致向回收站中添加了个相同的表
(4)为了确保添加到回收站中的对象的名称都是唯一的,系统会对这些保存到回收站中的对象进行重命名
2.程序讲解
通过show recyclebin命令可以查询oracle回收站的删除的信息
如果要闪回,则执行命令:
flashback table backtable to before drop;
注,如果两个命名相同,不能够闪回,可以起别名:为:
flashback table backtable to before drop rename to a;


四  闪回版本查询
闪回版本查询,提供了一个审计行改变的查询功能,通过它可以查找到所有已经提交了的行记录
1.首先来创建一个表
create table version_table(id number,content varchar2(20));
2.向表中插入数据和更新数据
  insert into version_table values(1,'Tom');
 insert into version_table values(2,'Tom');
向表中更新数据
update version_table set ename='tom11' where id=2;
3.通过闪回版本的查询获取该历史的记录
 select id,ename,versions_operation,versions_starttime,versions_endtime from version_table versionsbetween timestamp minvalue and maxvalue;
4.通过时间段来闪回	
select empno,ename,versions_operation,versions_starttime,versions_endtime from version_table versions between timestamp to_date('2012-03-22 14:42:19','yyyy-mm-dd hh24:mi:ss') 
and to_date('2012-03-22 14:43:28','yyyy-mm-dd hh24:mi:ss');

五  闪回事务查询
1.查询事务的信息
 desc flashback_transaction_query;
2.创建表
create table transaction_table (id number,ename varchar(20));
3.向表中插入数据
insert into transaction_table values(1,'tom');
insert into transaction_table values(2,'tom');
update transaction_table set ename='Tom123' where id=1;
4. 先通过闪回版本查询获取事务相关信息
SQL> select id,ename,versions_operation,versions_xid from transaction_table versions between timestamp minvalue and maxvalue;
 
        ID ENAME                VERSIONS_OPERATION VERSIONS_XID
---------- -------------------- ------------------ ----------------
         2 sdfd                 U                  04001400EE010000
         1 Tom123               I                  020022002F020000
         2 tom                  I                  020022002F020000

5.执行闪回事务查询
select xid,operation,table_name,undo_sql from flashback_transaction_query where xid='04001400EE010000';



 

1
0

查看评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
    个人资料
    • 访问:287131次
    • 积分:5175
    • 等级:
    • 排名:第5515名
    • 原创:221篇
    • 转载:18篇
    • 译文:0篇
    • 评论:149条
    文章分类
    最新评论