主頁 > 知識(shí)庫 > Oracle 11g 新特性 Flashback Data Archive 使用實(shí)例

Oracle 11g 新特性 Flashback Data Archive 使用實(shí)例

熱門標(biāo)簽:外呼電話系統(tǒng)用卡嗎 地圖標(biāo)注怎么保存 七日殺a19.5全地圖標(biāo)注 廣東營銷智能外呼系統(tǒng)商家 騰訊地圖標(biāo)注要費(fèi)用嗎 N個(gè)你智能電銷機(jī)器人 電渠外呼系統(tǒng) 車瑪仕極限運(yùn)動(dòng)場(chǎng)所地圖標(biāo)注 高德地圖標(biāo)注公司名字大全

Flashback Data Archive(閃回日志歸檔)其實(shí)理解為長時(shí)間的保存undo數(shù)據(jù),對(duì)于某些重要的表可以自定義它的歷史記錄保存期限,它的的種種行為與undo表空間十分相似,使用的時(shí)候也是完全透明的,用戶不知道它的查詢一致性視圖數(shù)據(jù)是來自u(píng)ndo還是Flashback Data Archive,現(xiàn)來分析它與undo的幾點(diǎn)不同:

1.Flashback Data Archive僅記錄UPDATE和DELETE語句,不記錄INSERT語句。

2.Flashback Data Archive中的行數(shù)據(jù)庫可以保存非常長的時(shí)間,甚至是幾十年,相比之下的undo數(shù)據(jù)中的對(duì)象通常只有幾個(gè)小時(shí)或者幾天的保留期限。

3.Flashback Data Archive和undo的本質(zhì)功能是不同的,它只關(guān)注表行的歷史改動(dòng),而非undo來實(shí)現(xiàn)數(shù)據(jù)庫整體事務(wù)的讀一致性,已經(jīng)回滾操作等。

那么Flashback Data Archive是怎么實(shí)現(xiàn)的呢,設(shè)想既然是保存表中的行記錄,應(yīng)該是需要單獨(dú)的存儲(chǔ)區(qū)域來記載行記錄的,為這個(gè)區(qū)域指定保留期限,這樣其中的數(shù)據(jù)就會(huì)長久的保留下去,然后再在想要記錄的表上添加跟蹤標(biāo)記,這樣就可以實(shí)現(xiàn)行記錄的歸檔保存了,實(shí)際上這便是Oracle的實(shí)現(xiàn)原理,這里的存儲(chǔ)區(qū)域就是Flashback Data Archive,在使用過程中使用create flashback archive命令創(chuàng)建。

一、創(chuàng)建歸檔

Oracle建議使用單獨(dú)的表空間來存儲(chǔ)Flashback Data Archive,當(dāng)然也可以在一個(gè)已經(jīng)存在的表空間上創(chuàng)建一個(gè)或多個(gè)Flashback Data Archive,

–創(chuàng)建前需要保證執(zhí)行用戶具有FLASHBACK_ARCHIVE_ADMINISTRER權(quán)限,該權(quán)限包括創(chuàng)建和修改flashback archive,啟用表跟蹤,管理歸檔中的表空間等)

復(fù)制代碼 代碼如下:

SQL> create tablespace fbda1
2  datafile '/u01/app/oracle/oradata/prod/fbda01.dbf'
3  size 5g;

Tablespace created.

接下來開始創(chuàng)建Flashback Data Archive:

復(fù)制代碼 代碼如下:

SQL> create flashback archive fb_01
2  tablespace fbda1 quota 300m
3  retention 10 year;

Flashback archive created.

上面的命令創(chuàng)建了一個(gè)保存十年的Flashback Data Archive,它可以使用fbda1表空間中300m的空間(有點(diǎn)小了。。。),根據(jù)需要我們可以再創(chuàng)建一個(gè)默認(rèn)的歸檔,使用default關(guān)鍵字,如

復(fù)制代碼 代碼如下:

SQL> create flashback archive default fb_dflt
2  tablespace fbda1
3  retention 1 year
4  /

Flashback archive created.

查詢DBA_FLASHBACK_ARCHIVE視圖獲取歸檔的信息,包括保留期限,狀態(tài)等

復(fù)制代碼 代碼如下:

SQL> select OWNER_NAME,FLASHBACK_ARCHIVE_NAME,
2  FLASHBACK_ARCHIVE#,RETENTION_IN_DAYS,STATUS
3  from dba_flashback_archive;
 
OWNER_NAME FLASHBACK_ARCHIVE_NAME FLASHBACK_ARCHIVE# RETENTION_IN_DAYS STATUS
---------- ---------------------- ------------------ ----------------- -------
SYS        FB_01                                   1              3650
SYS        FB_DFLT                                 2               365 DEFAULT

查詢FLASHBACK_ARCHIVE_TS視圖獲取表空間和歸檔的對(duì)應(yīng)關(guān)系

復(fù)制代碼 代碼如下:

SQL> select * from dba_flashback_archive_ts;

FLASHBACK_ARCHIVE_NAME    FLASHBACK_ARCHIVE# TABLESPACE_NAME      QUOTA_IN_MB
------------------------- ------------------ -------------------- ------------
FB_01                                      1 FBDA1                300
FB_DFLT                                    2 FBDA1

二、跟蹤表到指定的Flashback Data Archive中

將scott用戶的emp表分配到fb_01歸檔下:

復(fù)制代碼 代碼如下:

SQL> alter table scott.emp flashback archive fb_01;

Table altered.

查詢DBA_FLASHBACK_ARCHIVE_TABLES視圖可以獲得已經(jīng)歸檔的表:

復(fù)制代碼 代碼如下:

SQL> select * from dba_flashback_archive_tables;

TABLE_NAME OWNER_NAME FLASHBACK_ARCHIVE_NA ARCHIVE_TABLE_NAME   STATUS
---------- ---------- -------------------- -------------------- --------
EMP        SCOTT      FB_01                SYS_FBA_HIST_73181   ENABLED

三、查詢使用Flashback Data Archive

這里的使用和undo完全沒有異樣了,在查詢中指定as of就可以了,這里演示查詢3年前的emp表數(shù)據(jù):

復(fù)制代碼 代碼如下:

SQL> select empno,ename,hiredate
 2 from scott.emp
 3 as of timestamp (systimestamp - interval '3' year)
 4 where empno=7934;

EMPNO ENAME      HIREDATE
 ---------- ---------- ---------
 7934 MILLER     23-JAN-82

您可能感興趣的文章:
  • 在MySQL中使用mysqlbinlog flashback的簡(jiǎn)單教程
  • oracle中誤刪除表后恢復(fù)語句(FLASHBACK)
  • MySQL閃回(flashback)原理與實(shí)戰(zhàn)

標(biāo)簽:蘇州 來賓 長沙 玉樹 遼寧 大興安嶺 贛州 棗莊

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Oracle 11g 新特性 Flashback Data Archive 使用實(shí)例》,本文關(guān)鍵詞  Oracle,11g,新特性,新,特性,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《Oracle 11g 新特性 Flashback Data Archive 使用實(shí)例》相關(guān)的同類信息!
  • 本頁收集關(guān)于Oracle 11g 新特性 Flashback Data Archive 使用實(shí)例的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章