閃回技術包括以下特性:
(1)閃回查詢允許用戶查詢過去某個時間點的數據,以重新構建由於意外刪除或更改而丟失的數據。
(2)閃回版本查詢提供了一種查看行級數據庫隨時間變化的方法。
(3)閃回事務查詢提供了一種查看事務級數據庫變化的方法。
(4)閃回數據庫是進行時間點恢復的新策略。它能夠快速將Oracle 數據庫恢復到以前的時間,正確更正由於邏輯數據損壞或用戶錯誤而引起的任何問題。
(5)閃回表功能使 DBA 可以非常快速、輕鬆地將一個表或一組表恢復至過去特定的某一時間點。
(6)閃回刪除在刪除對象時提供了一個安全網,您可以非常快速、輕鬆地取消對一個表及其相關對象對象的刪除。
Flashback技術是以Undo Segment中的內容爲基礎的, 因此受限於UNDO_RETENTON參數。要使用flashback 的特性,必須啓用自動撤銷管理表空間。閃回參數如下:
Connected to Oracle Database 11g Enterprise Edition Release 11.1.0.7.0
Connected as system@LOCAL_DB
SQL> show parameter undo_
NAME TYPE VALUE
------------------------------------ ----------- ------------------------------
undo_management string AUTO
undo_retention integer 900 --默認是1440 即24*60,只保留一天的閃回數據,具體值在安裝數據庫實例時可以設置
undo_tablespace string UNDOTBS1
接下來講講oracle數據庫閃回類型主要有三種:
(1)閃回數據庫(flashback database)
閃回數據庫就是當出現邏輯錯誤時,能夠將整個數據庫回退到出錯前的那個狀態。
(2)閃回刪除(flashback drop)
Oracle10g之前,一旦刪除了一個表,那麼該表就會從數據字典裏面刪除。要恢復該表,需要進行不完全恢復。
Oracle10g以後,當我們刪除表時,默認Oracle只是在數據庫字典裏面對被刪的表的進行了重命名,並沒有真正的把表刪除。
(3)閃回表(flashback table)
所謂閃回表,就是將表裏的數據會退到歷史上的某個時間點,例如回退到用戶誤刪除數據之前的時間點,從而將誤刪除的數據恢復回來,在這個過程中,數據庫仍然可用,而且不需要類似於閃回日誌一樣的額外空間。閃回表利用的是undo表空間裏記錄的數據被改變前的值,如果閃回表所需要的undo數據,由於保留的時間超過了初始化參數undo_retention所指定的值,從而導致該undo數據塊被其他事務覆蓋,就不能恢復到指定的時間點了。
一、閃回數據庫詳解
Flashback Database整個架構包括一個進程Recover Writer(RVWR)後臺進程、Flashback Database Log日誌和Flash Recovery Area。閃回數據庫的實現機理是閃回日誌,只要配置了閃回數據庫,就會自動創建閃回日誌。只要數據庫裏的數據發生變化,oracle會將數據修改前的舊值保存在閃回日誌中。
數據庫的Flashback Database功能缺省是關閉的,要想啓用這個功能,就需要做如下配置。
(1)數據庫配置爲歸檔模式
SQL> select log_mode from v$database;
LOG_MODE
------------
NOARCHIVELOG
SQL> archive log list;
數據庫日誌模式 非存檔模式
自動存檔 禁用
存檔終點 USE_DB_RECOVERY_FILE_DEST
最早的聯機日誌序列 320
當前日誌序列 322
1、啓動歸檔爲歸檔模式(其與將非歸檔模式轉爲歸檔模式步驟相似):
(1)保存一致性,先關閉數據庫
shutdown immediate ;
(2)啓動到mount階段
startup mount;
(3)啓動閃回功能
alter database flashback on; --alter database archivelog;將數據庫改爲規檔模式
(4)切換到open階段
alter database open;
(5)對數據做一個完整備份
full backup --可以使用數據泵(expdp)或者使用RMAN
啓動閃回功能完善。
2、配置閃回恢復區(flash recovery area FRA)
SQL> show parameter db_recovery_file
NAME TYPE VALUE
------------------------------------ ----------- ------------------------------
db_recovery_file_dest string D:\app\flash_recovery_area
db_recovery_file_dest_size big integer 2G
一般在安裝數據庫實例時,會讓你選擇是否開啓oracle數據閃回功能,默認是開啓的,安裝過程中可以配置閃迴路徑以及閃回空間的大小。
3、配置閃回保留時間
SQL> show parameter db_flashback_retention_target
NAME TYPE VALUE
------------------------------------ ----------- ------------------------------
db_flashback_retention_target integer 1440
db_flashback_retention_target參數用來控制flashback log 數據保留的時間,默認值是1440,單位是minute,即24小時。
4、啓動數據庫實例即可
5、獲取當前時間點和SCN
SQL> select dbms_flashback.get_system_change_number from dual;
GET_SYSTEM_CHANGE_NUMBER
------------------------
13081009
SQL> select to_char(systimestamp,'yyyy-mm-dd HH24:MI:SS') as sysdt from dual;
SYSDT
-------------------
2013-08-25 21:12:46
SQL> conn scott/tiger
SQL> truncate table dept;
truncate table dept
*
ERROR at line 1:
ORA-02266: unique/primary keys in table referenced by enabled foreign keys
有時候對應的中文錯誤提示爲:ORA-02266: 表中的唯一/主鍵被啓用的外部關鍵字引用,一般出現這個錯誤,是因爲表中的主鍵被其它表的外鍵所引用,導致刪除數據時出錯。
SQL> alter table dept DISABLE PRIMARY KEY CASCADE;
Table altered.
SQL> truncate table dept;
Table truncated.
Flashback Database 實際是對數據庫的一個不完全恢復操作,因爲需要關閉數據庫重啓到mount狀態。
SQL> shutdown immediate;
數據庫已經關閉。
已經卸載數據庫。
ORACLE 例程已經關閉。
SQL> startup mount;
ORACLE 例程已經啓動。
Total System Global Area 1071333376 bytes
Fixed Size 1348508 bytes
Variable Size 385879140 bytes
Database Buffers 679477248
bytes Redo Buffers 4628480 bytes
數據庫裝載完畢。
SQL> flashback database to timestamp to_timestamp('2013-08-25 21:12:46','yyyy-mm-dd HH24:MI:SS');
閃回完成。
或者使用 SQL> flashback database to scn 13081009;
在執行完flashback database 命令之後,oracle 提供了兩種方式讓你修復數據庫:
1)直接alter database open resetlogs打開數據庫,當然,指定scn或者timestamp時間點之後產生的數據統統丟失。
2)先執行alter database open read only命令以read-only模式打開數據庫,然後立刻通過邏輯導出的方式將誤操作涉及表的數據導出,再執行recover database命令以重新應用數據庫產生的redo,將數據庫修復到flashback database 操作前的狀態,然後再通過邏輯導入的方式,將之前誤操作的表重新導入,這樣的話對現有數據的影響最小,不會有數據丟失。
SQL>alter database open read only;
查詢被truncate的表,是否已經閃回數據。
SQL> select deptno from dept;
deptno
----------------------------------------
0105206000001
0105108040001
0105304000001
0105304010001
010560001
0105600010001
0105601000001
0105602000001
證明閃回成功。
二、閃回刪除
Oracle10g以後,當我們刪除表時,默認Oracle只是在數據庫字典裏面對被刪的表的進行了重命名,並沒有真正的把表刪除。
回收站(recyclebin):用來維護表被刪除前的名字與刪除後系統生成的名字之間的對應關係的數據字典,表上的相關對象(索引、觸發器等)也會一併進入回收站。
SQL> show parameter recycle
NAME TYPE VALUE
------------------------------------ ----------- ------------------------------
buffer_pool_recycle string
db_recycle_cache_size big integer 0
recyclebin on
實例一:閃回sys用戶下的表
SQL> select * from user_recyclebin;
OBJECT_NAME ORIGINAL_NAME OPERATION TYPE TS_NAME CREATETIME DROPTIME DROPSCN PARTITION_NAME CAN_UNDROP CAN_PURGE RELATED BASE_OBJECT
PURGE_OBJECT SPACE
------------------------------ -------------------------------- --------- ------------------------- ------------------------------ ------------------- ------------------- ---------- -------------------------------- ---------- --------- ---------- -----------
------------ ----------
SQL> drop table dept;
Table dropped
SQL> select * from user_recyclebin;
OBJECT_NAME ORIGINAL_NAME OPERATION TYPE TS_NAME CREATETIME DROPTIME DROPSCN PARTITION_NAME CAN_UNDROP CAN_PURGE RELATED BASE_OBJECT
PURGE_OBJECT SPACE
------------------------------ -------------------------------- --------- ------------------------- ------------------------------ ------------------- ------------------- ---------- -------------------------------- ---------- --------- ---------- -----------
------------ ----------
SQL>flashback table dept to before drop; --或者使用(flashback table dept to before drop rename to dept_bak;)
報如下錯誤:ORA-38305: 對象不在回收站中
原因:Flashback不支持sys用戶與system表空間下的對象,也不能從回收站裏拿到。故使用SYS或者SYSTEM用戶登陸時,show recyclebin爲空。
實例二:閃回非sys、system用戶下的表
SQL> drop table DEPT_BAK;
Table dropped
SQL> select * from user_recyclebin a where a.original_name = 'DEPT_BAK';
OBJECT_NAME ORIGINAL_NAME OPERATION TYPE TS_NAME CREATETIME DROPTIME DROPSCN PARTITION_NAME CAN_UNDROP CAN_PURGE RELATED BASE_OBJECT
PURGE_OBJECT SPACE
------------------------------ -------------------------------- --------- ------------------------- ------------------------------ ------------------- ------------------- ---------- -------------------------------- ---------- --------- ---------- -----------
------------ ----------
BIN$BnpnsFC8SfSYdJ7Qio0k2g==$0 DEPT_BAK DROP TABLE TESTSPACE 2013-04-21:15:38:04 2013-08-25:22:11:45 13087074 YES YES 745783 745783
745783 8
SQL> flashback table DEPT_BAK to before drop;
Done
備註:
1、 禁用與啓用recyclebin該功能:
SQL> alter system set recyclebin=off;
SQL> alter system set recyclebin=on;
禁用後刪除的對象將直接刪除,不會寫到Recyclebin中,當然在刪除時,指定purge參數,表也將直接刪除,不會寫到recyclebin中。
SQL> drop table name purge;
2)關於purge命令
表空間的RecycleBin區域只是一個邏輯區域,而不是從表空間上物理的劃出一塊區域固定用於回收站,因此RecycleBin是和普通對象共用表空間的存儲區域,或者說是RecycleBin的對象要和普通對象搶奪存儲空間。當發生空間不夠時,Oracle會按照先入先出的順序覆蓋RecycleBin中的對象。也可以手動的刪除Recycle Bin佔用的空間。
1)Purge tablespace tablespace_name; 用於清空表空間的RecycleBin
2)Purge tablespace tablespace_name user user_name; 清空指定表空間的Recycle Bin中指定用戶的對象
3)Purge recyclebin; 刪除當前用戶的Recycle Bin中的對象
4)Purge dba_recyclebin 刪除所有用戶的Recycle Bin中的對象,該命令要sysdba權限
5)Drop table table_name purge; 刪除對象並且不放在Recycle Bin中,即永久的刪除,不能用Flashback恢復。
6)Purge index recycle_bin_object_name; 當想釋放Recycle bin的空間,又想能恢復表時,可以通過釋放該對象的index所佔用的空間來緩解空間壓力。因爲索引是可以重建的。
三、閃回表
查詢過去某個時刻表的數據的情況,一旦確認某個時刻的數據滿足我們的需求以後,可以根據這個時間執行閃回表。
ORA-08189: 因爲未啓用行移動功能, 不能閃回表,需要先執行一個命令:ALTER TABLE dept ENABLE ROW MOVEMENT。
語法一:
select * from dept
VERSIONS BETWEEN TIMESTAMP SYSTIMESTAMP - INTERVAL '1' DAY AND SYSTIMESTAMP -INTERVAL '1' HOUR;
語法二:
select * from dept as of timestamp to_timestamp('2013-08-25 21:12:46','yyyy-mm-dd HH24:MI:SS');
語法三:
select * from dept as of scn 13081009;
語法四:
select * from flashback_transaction_query a where a.table_name='DEPT';
附註:interval用法
Oracle語法:
INTERVAL '{ integer | integer time_expr | time_expr }' { { DAY | HOUR | MINUTE } [ ( leading_precision ) ] | SECOND [ ( leading_precision
[, fractional_seconds_precision ] ) ] } [ TO { DAY | HOUR | MINUTE | SECOND [ (fractional_seconds_precision) ] } ]
leading_precision值的範圍是0到9, 默認是2. time_expr的格式爲:HH[:MI[:SS[.n]]] or MI[:SS[.n]] or SS[.n], n表示微秒.
該類型與INTERVAL YEAR TO MONTH有很多相似的地方,建議先看INTERVAL YEAR TO MONTH再看該文.
INTERVAL '20' DAY - INTERVAL '240' HOUR = INTERVAL '10-0' DAY TO SECOND
表示: 20天 - 240小時 = 10天0秒
INTERVAL '30.12345' SECOND(2,4)
表示: 30.1235秒, 因爲該地方秒的後面精度設置爲4, 要進行四捨五入.
查詢tableA中10分鐘前的數據(閃回查詢,前提:undo沒有被覆蓋..如果undo被覆蓋,查詢會失敗)
Select * From table dept As Of Timestamp (systimestamp - Interval '10' minute);