ORACLE數(shù)據(jù)庫閃回查詢用法詳解
前言
Oracle ??閃回查詢(Flashback Query)?? 是 Oracle 數(shù)據(jù)庫提供的一種強(qiáng)大功能,它允許用戶 ??查看表在某個(gè)過去時(shí)間點(diǎn)或系統(tǒng)變更號(hào)(SCN)時(shí)的數(shù)據(jù)狀態(tài)??,就好像“時(shí)光倒流”一樣,??不用恢復(fù)數(shù)據(jù)庫或執(zhí)行復(fù)雜的備份還原操作??。
一、什么是閃回查詢?
??閃回查詢(Flashback Query)?? 是 Oracle 提供的一種機(jī)制,讓你可以查詢表在 ??過去某個(gè)時(shí)間點(diǎn)?? 或 ??某個(gè)系統(tǒng)更改號(hào)(SCN, System Change Number)?? 的數(shù)據(jù)內(nèi)容。
? 簡單來說:你可以“查過去的數(shù)據(jù)”,而不用真的把數(shù)據(jù)庫回退到那個(gè)時(shí)間點(diǎn)。
二、閃回查詢解決了什么問題?
在實(shí)際工作中,我們可能會(huì)遇到如下問題:
??誤刪了某條數(shù)據(jù),但還沒提交或剛提交不久,想找回。??
??誤更新了數(shù)據(jù),想看看更新前的值是什么。??
??某個(gè)表的數(shù)據(jù)被錯(cuò)誤修改,但不確定什么時(shí)候發(fā)生的,想查歷史某個(gè)時(shí)刻的值。??
??不想做完整的數(shù)據(jù)庫恢復(fù),只想查看某一時(shí)刻的數(shù)據(jù)快照。??
傳統(tǒng)的做法可能是:
從備份恢復(fù)(很麻煩,影響生產(chǎn))
有日志但分析復(fù)雜
沒有事先做觸發(fā)器或?qū)徲?jì)
而 ??閃回查詢提供了一種輕量級(jí)、無需恢復(fù)的“數(shù)據(jù)歷史查看”能力。??
三、閃回查詢的基本用法
語法格式(以 SELECT 為例):
SELECT * FROM 表名 AS OF TIMESTAMP TO_TIMESTAMP('2024-06-01 10:00:00', 'YYYY-MM-DD HH24:MI:SS')
WHERE 條件;或者使用 ??SCN(系統(tǒng)更改號(hào))??:
SELECT * FROM 表名 AS OF SCN 12345678 WHERE 條件;
?? 說明:
AS OF TIMESTAMP:基于某個(gè)具體的時(shí)間點(diǎn)查詢過去的數(shù)據(jù)。
AS OF SCN:基于系統(tǒng)更改號(hào)(SCN),更加精確(通常用于高級(jí)恢復(fù)或與 LogMiner 配合)。
四、舉個(gè)例子
假設(shè)你有一個(gè)員工表 employees,在 ??今天上午 10:00?? 誤刪或誤更新了一些數(shù)據(jù),你想查看 ??10:00 時(shí)該表的數(shù)據(jù)狀態(tài)??,可以這樣查:
示例 1:基于時(shí)間戳查詢過去的數(shù)據(jù)
SELECT *
FROM employees AS OF TIMESTAMP TO_TIMESTAMP('2024-06-01 10:00:00', 'YYYY-MM-DD HH24:MI:SS')
WHERE employee_id = 100;這條語句的意思是:??查詢 employees 表在 2024年6月1日 10點(diǎn)整的時(shí)候,employee_id=100 的那行數(shù)據(jù)是什么樣的。??
示例 2:基于 SCN 查詢(更精確)
SELECT * FROM employees AS OF SCN 12345678 WHERE employee_id = 100;
?? SCN 是 Oracle 內(nèi)部用來標(biāo)識(shí)數(shù)據(jù)庫變化的一個(gè)數(shù)字,每發(fā)生一次提交都會(huì)遞增。你可以通過函數(shù)
DBMS_FLASHBACK.GET_SYSTEM_CHANGE_NUMBER獲取當(dāng)前的 SCN,或者從日志/監(jiān)控工具中獲取某個(gè)時(shí)間點(diǎn)的 SCN。
五、如何獲取當(dāng)前 SCN 或時(shí)間對(duì)應(yīng)的 SCN?
查看當(dāng)前 SCN:
SELECT DBMS_FLASHBACK.GET_SYSTEM_CHANGE_NUMBER FROM dual;
或者:
SELECT current_scn FROM v$database;
這會(huì)返回當(dāng)前數(shù)據(jù)庫的 SCN 號(hào),你可以用它來做閃回查詢。
六、閃回查詢的原理是什么?
Oracle 通過 ??UNDO 表空間(回滾段)?? 保存了事務(wù)發(fā)生前后的舊數(shù)據(jù)(也就是數(shù)據(jù)修改前的版本),閃回查詢其實(shí)就是去 ??UNDO 中找指定時(shí)間點(diǎn)或 SCN 的舊數(shù)據(jù)??。
?? 注意:
??UNDO 數(shù)據(jù)不是永久保存的??,它有一個(gè)保留時(shí)間(由
UNDO_RETENTION參數(shù)控制,默認(rèn)可能是幾分鐘到幾小時(shí))。如果你要查詢的時(shí)間點(diǎn)距離現(xiàn)在太久,UNDO 數(shù)據(jù)可能已經(jīng)被覆蓋,這時(shí)候閃回查詢就查不到了!
七、閃回查詢能查多久之前的數(shù)據(jù)?
取決于:
??UNDO 表空間的大小??
??UNDO 數(shù)據(jù)的保留時(shí)間(UNDO_RETENTION 參數(shù),單位是秒,默認(rèn)可能是 900 秒 = 15 分鐘,可配置更長)??
??數(shù)據(jù)庫的負(fù)載和事務(wù)量(事務(wù)多,UNDO 數(shù)據(jù)被覆蓋得快)??
?? 所以:??閃回查詢適合查詢“最近一段時(shí)間內(nèi)”的數(shù)據(jù)??,不能替代完整的備份恢復(fù)方案。
八、閃回查詢 vs 閃回表 vs 閃回?cái)?shù)據(jù)庫
Oracle 還提供了其他幾種 “閃回” 相關(guān)功能,它們的能力范圍不同:
功能 | 說明 | 能否恢復(fù)數(shù)據(jù)? | 是否需要恢復(fù)操作? |
|---|---|---|---|
??閃回查詢(Flashback Query)?? | 查詢過去某個(gè)時(shí)間點(diǎn)的表數(shù)據(jù) | ? 只能查,不能直接改 | 否,只是查詢 |
??閃回表(Flashback Table)?? | 將整張表恢復(fù)到某個(gè)時(shí)間點(diǎn)(撤銷 DML 操作) | ? 可以恢復(fù)表數(shù)據(jù) | 否,一條 SQL 搞定 |
??閃回刪除(Flashback Drop)?? | 恢復(fù)被 DROP 的表 | ? 可以找回被刪的表 | 否 |
??閃回?cái)?shù)據(jù)庫(Flashback Database)?? | 將整個(gè)數(shù)據(jù)庫回退到過去某個(gè)時(shí)間點(diǎn) | ? 整庫恢復(fù) | 是,需配置并重啟 |
? 如果你只是想“看看過去的數(shù)據(jù)長什么樣”,用 ??閃回查詢?? 就夠了。
? 如果你希望??直接恢復(fù)某張表到過去的狀態(tài)??,可以用 ??閃回表(Flashback Table)??。
九、總結(jié):Oracle 閃回查詢 是什么?
??Oracle 閃回查詢(Flashback Query)是一種允許用戶查詢表在過去某個(gè)時(shí)間點(diǎn)或 SCN 時(shí)的數(shù)據(jù)內(nèi)容的功能,它基于 UNDO 數(shù)據(jù),無需恢復(fù)數(shù)據(jù)庫,是一種輕量級(jí)的數(shù)據(jù)歷史查看機(jī)制。??
主要用途:
查誤刪/誤更新前的數(shù)據(jù)
審計(jì)或核對(duì)歷史數(shù)據(jù)
不需要恢復(fù)、不影響生產(chǎn)環(huán)境
基本語法:
SELECT * FROM 表名 AS OF TIMESTAMP TO_TIMESTAMP('2024-06-01 10:00:00', 'YYYY-MM-DD HH24:MI:SS') WHERE ...;
或
SELECT * FROM 表名 AS OF SCN 12345678 WHERE ...;注意事項(xiàng):
依賴 UNDO 數(shù)據(jù),時(shí)間太久可能查不到
只能查,不能直接改(若要恢復(fù)數(shù)據(jù),可結(jié)合閃回表或其他方法)
如你想要實(shí)現(xiàn)“誤操作后快速恢復(fù)數(shù)據(jù)”,不僅可以靠閃回查詢,還可以進(jìn)一步使用 ??閃回表(Flashback Table)??,甚至做 ??數(shù)據(jù)備份與時(shí)間點(diǎn)恢復(fù)(PITR)??。需要的話,我可以繼續(xù)為你講解這些進(jìn)階功能!
總結(jié)
到此這篇關(guān)于ORACLE數(shù)據(jù)庫閃回查詢用法詳解的文章就介紹到這了,更多相關(guān)ORACLE數(shù)據(jù)庫閃回內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Oracle 12CR2查詢轉(zhuǎn)換教程之臨時(shí)表轉(zhuǎn)換詳解
這篇文章主要給大家介紹了關(guān)于Oracle 12CR2查詢轉(zhuǎn)換教程之臨時(shí)表轉(zhuǎn)換的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2018-11-11
Oralce中VARCHAR2()與NVARCHAR2()的區(qū)別介紹
這篇文章主要給大家詳細(xì)介紹了關(guān)于Oralce中VARCHAR2()與NVARCHAR2()的區(qū)別,文中先通過翻譯官方的介紹進(jìn)行區(qū)別總結(jié),然后由一個(gè)實(shí)戰(zhàn)示例代碼進(jìn)行演示,相信對(duì)大家的理解會(huì)很有幫助,有需要的朋友們下面來跟著小編一起看看吧。2016-12-12
詳解PL/SQL Developer連接本地Oracle 11g 64位數(shù)據(jù)庫
本篇文章主要介紹了PL/SQL Developer連接本地Oracle 11g 64位數(shù)據(jù)庫 ,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-04-04

