ITPub博客

首页 > Linux操作系统 > Linux操作系统 > 数据库flashback

数据库flashback

原创 Linux操作系统 作者:victorymoshui 时间:2011-05-03 23:32:02 0 删除 编辑

[oracle@rhel5 ~]$ sqlplus / as sysdba

SQL*Plus: Release 10.2.0.1.0 - Production on Tue Nov 30 22:56:46 2010

Copyright (c) 1982, 2005, Oracle. All rights reserved.


Connected to:
Oracle Database 10g Enterprise Edition Release 10.2.0.1.0 - Production
With the Partitioning, OLAP and Data Mining options

SQL>

查看数据库能闪回到的最早的scn,如果数据库没有开闪回功能是没有记录返回的。
SQL> select oldest_flashback_scn from v$flashback_database_log;

no rows selected

查看数据库是否开闪回
SQL> select flashback_on from v$database;

FLASHBACK_ON
------------------
NO

数据库open状态尝试开启数据库的闪回功能,返回报错信息说明需要在mount状态下来操作。
SQL> alter database flashback on;
alter database flashback on
*
ERROR at line 1:
ORA-38759: Database must be mounted by only one instance and not open.

关闭数据库
SQL> shutdown immediate
Database closed.
Database dismounted.
ORACLE instance shut down.

打开数据库到mount状态
SQL> startup mount
ORACLE instance started.

Total System Global Area 184549376 bytes
Fixed Size 1218412 bytes
Variable Size 83888276 bytes
Database Buffers 96468992 bytes
Redo Buffers 2973696 bytes
Database mounted.

数据库在mount状态下再次尝试开启数据库的闪回功能,又返回错误信息说明数据库在非归档状态下不支持数据库的闪回。
SQL> alter database flashback on;
alter database flashback on
*
ERROR at line 1:
ORA-38706: Cannot turn on FLASHBACK DATABASE logging.
ORA-38707: Media recovery is not enabled.

开归档
SQL> alter database archivelog;

Database altered.

开闪回成功
SQL> alter database flashback on;

Database altered.

打开数据库
SQL> alter database open;

Database altered.

开启归档,默认的归档目录:USE_DB_RECOVERY_FILE_DEST ,与9i不同10g开启归档很要简单一些。以后可以自行修改归档目录的位置,在此暂时保留默认。
SQL> archive log list
Database log mode Archive Mode
Automatic archival Enabled
Archive destination USE_DB_RECOVERY_FILE_DEST
Oldest online log sequence 59
Next log sequence to archive 61
Current log sequence 61

检验数据库闪回是否开启
SQL> select flashback_on from v$database;

FLASHBACK_ON
------------------
YES

查看闪回区信息,默认安装大小为2G,根据数据库的具体情况作修改。
SQL> show parameter recover

NAME TYPE VALUE
------------------------------------ ----------- ------------------------------
db_recovery_file_dest string /u01/app/oracle/flash_recovery_area
db_recovery_file_dest_size big integer 20G
recovery_parallelism integer 0


数据库可以恢复到多少分钟以前,默认1440分钟(一天)
SQL> show parameter flash

NAME TYPE VALUE
------------------------------------ ----------- ------------------------------
db_flashback_retention_target integer 1440


查看数据库能恢复到最早的scn,和最早的时间
SQL> select oldest_flashback_scn,oldest_flashback_time from v$flashback_database_log;

OLDEST_FLASHBACK_SCN OLDEST_FLASHBACK_TIME
-------------------- ---------------------
1021372 20101130 23:07:18

===================oralce flashback 使用方法总结 ===================
 
oralce flashback 使用方法总结:
 
一,关键知识点
在oracle 10g中,如果是使用drop 把表对象删除了,会把这个对象放在回收站里
查看回收站:select * from recyclebin;
然后恢复对象:flashback table TABLENAME to before drop;
删除不放回回收站:drop table TABLENAME purge;
 
如果不小心误删除了某个表中的部分数据,需要恢复回来,可以利用oracle flashback闪回误删除的表数
据。但要注意:flashback table 需要下面几个条件:
1. 需要有flashback any table的系统权限或者是flashback这个表的对象权限;
2. 需要有对这个表的基本的dml,alter操作权限;
3. 必须保证该表row movement(这主要是让flashback记住表的rowid)
扩展:oracle flashback闪回不仅可以误删除的表数据,还可以错误的修改也可以恢复过来;
注意:
ORA-08189: cannot flashback the table because row movement is not enabled
但是抛出了8189错误,原因就是因为表没有row movement,改变下表的属性:
SQL> alter table test_tablename enable row movement;
再执行闪回操作;

二,实例
 
1.创建示例表:
CREATE TABLE TBL_TEST
(
ID    NUMBER,
NAME VARCHAR2(100 BYTE),
PID   NUMBER                                  DEFAULT 0
);

2.插入测试数据:
INSERT INTO TBL_TEST(ID,NAME,PID) VALUES('1','10','0');
INSERT INTO TBL_TEST(ID,NAME,PID) VALUES('2','11','1');
INSERT INTO TBL_TEST(ID,NAME,PID) VALUES('3','20','0');
INSERT INTO TBL_TEST(ID,NAME,PID) VALUES('4','12','1');
INSERT INTO TBL_TEST(ID,NAME,PID) VALUES('5','121','2');
 
3.恢复误删除的表数据
例如:
FlashBack table TBL_TEST to timestamp to_timestamp('2009-8-1 16:59:36','yyyy-mm-dd
hh24:mi:ss');
报错:ORA-08189: cannot flashback the table because row movement is not enabled
错误解决,要执行:alter table TBL_TEST enable row movement;
FlashBack table TBL_TEST to timestamp to_timestamp('2009-8-1 16:59:36','yyyy-mm-dd
hh24:mi:ss');
 
4.恢复误表数据错误的修改:
例如:
update TBL_TEST set pid=1 where id =5;
FlashBack table TBL_TEST to timestamp to_timestamp('2009-8-1 16:59:36','yyyy-mm-dd
hh24:mi:ss');
 
5.恢复被删除表的步骤:
(1)显示回收站信息
select * from RECYCLEBIN;
(2)确定被删除表存在后,可以恢复诶删除表,此时可以指定表明或者回收站对象名
  flashback table TBL_TEST to before drop;
  或 flashback table "BIN$zgwx7wCsQ92JRcrAVpABQg==$0" to before drop
  
6.恢复被删除表的同时可以改变被删除表的名称
flashback table TBL_TEST to before drop rename to test_TBL_TEST
或 flashback table "BIN$zgwx7wCsQ92JRcrAVpABQg==$0" to before drop rename to test_TBL_TEST
 
7.删除不放回回收站:
drop table TBL_TEST purge;
 
目前只在pl/sql developer 上,实际操作了上面几点,也是常用的知识点。可能还有其他的处理方法,如Flashback Database to time to_timestamp(xxx),这些有待继续研究。
 

本文出自 “在路上” 博客,请务必保留此出处http://yuwenhu.blog.**.com/672091/186601

 

 

 

================================flash back 闪回测试================================

 

--1. 开启数据库闪回功能
SQL> shutdown immediate
已经卸载数据库。
ORACLE 例程已经关闭。
SQL> startup mount
ORACLE 例程已经启动。
Total System Global Area  612368384 bytes
Fixed Size                  1250428 bytes
Variable Size             146803588 bytes
Database Buffers          457179136 bytes
Redo Buffers                7135232 bytes
数据库装载完毕。
SQL>alter database archivelog;
数据库已更改。
SQL>alter database flashback on ;
数据库已更改。
SQL> alter database open;
数据库已更改。
 
--2. 查看闪回模式下相关参数
 
SQL> archive log list
数据库日志模式            存档模式
自动存档             启用
存档终点            USE_DB_RECOVERY_FILE_DEST
最早的联机日志序列     773
下一个存档日志序列   775
当前日志序列           775
SQL> show parameter db_recover
NAME                                 TYPE        VALUE
------------------------------------ ----------- ------------------------------
db_recovery_file_dest                string      C:\oracle\product\10.2.0/flash_recovery_area
db_recovery_file_dest_size           big integer 2G
--闪回相关备份文件及文件大小
 
 
SQL> show parameter flashback
NAME                                 TYPE        VALUE
------------------------------------ ----------- ------------------------------
db_flashback_retention_target        integer     1440
--默认支持闪回的时间,单位为分。
 
SQL> select flashback_on from v$database;
FLASHBACK_ON
------------------
YES
 
--开启闪回功能后,启动RVWR(recover writer)进程。
SQL> col program format a18
SQL> col pid format 99
SQL> select program,pid,spid,background,pga_used_mem,pga_alloc_mem,pga_freeable_mem,pga_max_mem
  2  from v$process where program like '%RVWR%';
 
PROGRAM            PID SPID         B PGA_USED_MEM PGA_ALLOC_MEM PGA_FREEABLE_MEM PGA_MAX_MEM
------------------ --- ------------ - ------------ ------------- ---------------- -----------
ORACLE.EXE (RVWR)   16 2924         1       206881        623853                0      623853
 
SQL> select * from v$sgastat where name like '%flashback%';
POOL         NAME                            BYTES
------------ -------------------------- ----------
shared pool  flashback generation buff     3981204      
 
SQL> select * from v$sysstat where name like '%flashback log%';
STATISTIC# NAME                                                                  CLASS      VALUE    STAT_ID
---------- ---------------------------------------------------------------- ---------- ---------- ----------
       168 flashback log writes                                                      2         11 3123176560       
      
--3. 闪回数据库测试
SQL> create table yangxl as select * from dba_objects;
表已创建。
 
SQL> select count(1) from yangxl;
  COUNT(1)
----------
     52511
 
SQL> alter session set nls_date_format='YYYY-MM-DD HH24:MI:SS';
会话已更改。
 
SQL> select sysdate from dual;
SYSDATE
-------------------
2009-06-04 11:06:12
  
SQL> truncate table yangxl;
表被截断。
SQL> select * from yangxl;
 
未选定行 
 
SQL> shutdown immediate;
数据库已经关闭。
已经卸载数据库。
ORACLE 例程已经关闭。
 
SQL> startup mount;
ORACLE 例程已经启动。
Total System Global Area  612368384 bytes
Fixed Size                  1250428 bytes
Variable Size             150997892 bytes
Database Buffers          452984832 bytes
Redo Buffers                7135232 bytes
数据库装载完毕。
 
SQL> flashback database to timestamp to_timestamp('2009-06-04 11:06:12','yyyy-mm-dd hh24:mi:ss');
闪回完成。
SQL> alter database open;
alter database open
*
第 1 行出现错误:
ORA-01589: 要打开数据库则必须使用 RESETLOGS 或 NORESETLOGS 选项
 
SQL> alter database open resetlogs;
数据库已更改。
 
SQL> select count(*) from yangxl;
  COUNT(*)
----------
     52511
 

--4. 闪回表测试

SQL> select object_name,original_name,type from user_recyclebin;
未选定行
 
SQL> drop table yangxl;
表已删除。
 
SQL> select object_name,original_name,type from user_recyclebin where original_name = 'YANGXL';
 
OBJECT_NAME                    ORIGINAL_NAME                    TYPE
------------------------------ -------------------------------- -------------------------
BIN$93EgIpKgQb2UYDLGbvb7tQ==$0 YANGXL                           TABLE
BIN$9Bl7UGOgT36SmT9+7g7ijQ==$0 YANGXL                           TABLE
BIN$QlDzOZx8TWmM+YuaXYWIrA==$0 YANGXL                           TABLE
BIN$gr27sKM4T5imRUIE4Lu1eQ==$0 YANGXL                           TABLE
BIN$wSaMD+dxQxqEqR1RG/bJKA==$0 YANGXL                           TABLE
 
SQL> flashback table yangxl to before drop;
闪回完成。
 
SQL> select count(1) from yangxl;
  COUNT(1)
----------
         9
 
--5. 闪回表数据测试

--闪回表都可以,闪回数据肯定是没有问题的了。
SQL> select count(1) from yangxl;
  COUNT(1)
----------
         9
SQL> delete from yangxl where rownum = 1;
已删除 1 行。
 
SQL> commit;
提交完成。
 
SQL> flashback table yangxl to timestamp to_timestamp('2009-06-04 13:07:01','yyyy-mm-dd hh24:mi:ss');
flashback table yangxl to timestamp to_timestamp('2009-06-04 13:07:01','yyyy-mm-dd hh24:mi:ss')              *
第 1 行出现错误:
ORA-08189: 因为未启用行移动功能, 不能闪回表
 
SQL> alter table yangxl enable row movement;
表已更改。
 
SQL> flashback table yangxl to timestamp to_timestamp('2009-06-04 13:07:01','yyyy-mm-dd hh24:mi:ss');
闪回完成。
 
SQL> select count(1) from yangxl;
  COUNT(1)
----------
         9
        
--6. 回收站

SQL> show parameter recyclebin
NAME                                 TYPE        VALUE
------------------------------------ ----------- ------------------------------
recyclebin                           string      on       
 
SQL> alter system set recyclebin = off;
系统已更改。
 
SQL> show parameter recyclebin
NAME                                 TYPE        VALUE
------------------------------------ ----------- ------------------------------
recyclebin                           string      OFF
 
SQL> alter system set recyclebin = on;
系统已更改。
 
--清空回收站
purge user_recyclebin;
SQL> purge user_recyclebin;
回收站已清空。
 
SQL> select * from user_recyclebin;
未选定行
 
purge dba_recyclebin;
SQL> purge dba_recyclebin;
DBA 回收站已清空。

--清空本用户回收站和所有用户回收站(需SYS权限)
purge table <表名>;
SQL> purge table yangxl;
表已清除。
 
purge index <表名>;
SQL> purge index ind_yxl;
索引已清除。
 
从回收站清除表和索引
注:如果清除的对象在回收站中有同名的,那么会清除在回收站中时间更久的那个对象
 
purge tablespace <表空间名>;
 
清除回收站中指定表空间的所有对象
 
drop table <表名> purge;
 
直接彻底删除,不会放入回收站
 
--7. SYS 与闪回

1. 用户 SYS、SYSTEM 不支持闪回
2. 说明缺省SYSTEM表空间删除对象不放入回收站

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/9390331/viewspace-694380/,如需转载,请注明出处,否则将追究法律责任。

请登录后发表评论 登录
全部评论

注册时间:2009-08-26

  • 博文量
    173
  • 访问量
    306770