flashback query閃回數據

来源:https://www.cnblogs.com/oracle-ziyuhou/archive/2018/05/28/9101141.html
-Advertisement-
Play Games

誤刪除了部分重要數據,已提交,需要恢復。首先嘗試flashback query閃回數據。資料庫運行在歸檔模式,首先確認資料庫的SCN的變化:SQL> col fscn for 999999999999999999999SQL> col nscn for 999999999999999999999SQ ...


誤刪除了部分重要數據,已提交,需要恢復。
首先嘗試flashback query閃回數據。

資料庫運行在歸檔模式,首先確認資料庫的SCN的變化:

SQL> col fscn for 999999999999999999999
SQL> col nscn for 999999999999999999999
SQL> select name,first_change# fscn,next_change# nscn, first_time from v$archived_log;

NAME                                             FSCN     NSCN FIRST_TIME
----------------------------------------------------------------------------- ----------- ----------- ------------------
/u01/app/oracle/fast_recovery_area/CDB/CDB/archivelog/2018_05_28/o1_mf_1_3_fj      1547949     1550763 2018:05:2816:37:41
qj6z9t_.arc

/u01/app/oracle/fast_recovery_area/CDB/CDB/archivelog/2018_05_28/o1_mf_1_4_fj      1550763     1551171 2018:05:2816:42:07
qjsm3t_.arc

/u01/app/oracle/fast_recovery_area/CDB/CDB/archivelog/2018_05_28/o1_mf_1_5_fj      1551171     1551255 2018:05:2816:52:03
qjwkog_.arc

/u01/app/oracle/fast_recovery_area/CDB/CDB/archivelog/2018_05_28/o1_mf_1_6_fj      1551255     1551654 2018:05:2816:53:37
qjxycd_.arc


獲取當前的SCN:
SQL> select dbms_flashback.get_system_change_number  fscn from dual;

          FSCN
----------------------
           1551702
           

使用應用用戶嘗試閃回:
SQL> conn c##scott/tiger
Connected.

           
現有數據:
SQL> select count(*) from emp1;

  COUNT(*)
----------
     0

創建恢復表:
SQL> create table emp1_recov as select * from emp1 where 1=0;

Table created.

根據業務提供的大致誤操作時間,結合V$ARCHIVED_LOG視圖,選擇適當SCN向前執行閃回查詢:
 
SQL> select count(*) from emp1 as of scn 1551171;
select count(*) from emp1 as of scn 1551171
                     *
ERROR at line 1:
ORA-01466: unable to read data - table definition has changed

嘗試多個SCN,獲取最佳值(能知道具體時間,那麼可以獲取準確的數據恢復):

SQL> select count(*) from emp1 as of scn 1551255;

  COUNT(*)
----------
    14

SQL> select count(*) from emp1 as of scn 1551200;
select count(*) from emp1 as of scn 1551200
                     *
ERROR at line 1:
ORA-01466: unable to read data - table definition has changed


SQL> select count(*) from emp1 as of scn 1551233;
select count(*) from emp1 as of scn 1551233
                     *
ERROR at line 1:
ORA-01466: unable to read data - table definition has changed


SQL> select count(*) from emp1 as of scn 1551244;

  COUNT(*)
----------
    14


最後選擇恢復到SCN為1551244的時間點,代碼如下:
SQL> insert into emp1_recov select * from emp1 as of scn 1551244;

14 rows created.

SQL> commit;

Commit complete.

由業務人員通過emp1_recov表確認,向當前表補回誤刪除的數據,至此閃回恢覆成功。沒有閃回特性的話,需要通過物理備份執行不完全恢復,或者找出足夠及時的邏輯備份來進行恢復,其過程都可能是極其複雜的。






          


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 創建其他Session(User)的進程需要拿到對應Session的Token作為CreateProcessAsUser的參數來啟動進程。 修改有System許可權的Token的TokenId為其他Session的TokenId就可以在其他Session裡面創建有System許可權的進程了。 相關的Bl ...
  • Linux上部署SVN author:headsen chen 2017-10-16 16:45:04 前提:通過yum來安裝,必須是centos6.5的桌面版的。否則會出現某些的安裝包不全而導致裝好的svn不能用,等等未知的錯誤。個人原創,轉載必需註明作者,出處,否則依法追究法律責任 服務端安裝配 ...
  • 承自上一篇中的函數圖形,有人問,能不能別把畫個圖搞那麼複雜,我說當然,只要你有一臺mac。 話說出來很瀟灑的樣子,充斥著一股迷之自信。 可能這就是mac用戶典型的特征,儘管也許並沒有那麼值得驕傲。 其實在上一篇中我見到照片的時候就看出來用的是什麼軟體了,mac內置的grapher。grapher的誕 ...
  • Linux DNS原理簡介及配置 DNS簡介 DNS原理 功能變數名稱解析的過程 資源記錄 DNS BIND安裝配置 一、簡介 一般來講功能變數名稱比IP地址更加的有含義、也更容易記住,所以通常用戶更習慣輸入功能變數名稱來訪問網路中的資源,但是電腦主機在互聯網中只能通過IP識別對方主機,那麼就需要DNS功能變數名稱解析服務了。 ...
  • 首先展示錯誤信息: win10更新系統後,之前連接的伺服器都連接不上了,應該用一下方法解決: 運行 gpedit.msc,打開本地組策略:電腦配置>管理模板>系統>憑據分配>加密Oracle修正,選擇啟用,選擇易受攻擊。 ...
  • 安裝截圖軟體 1.下載安裝python-xlib apt-get install python-xlib 2.下載截圖軟體包 wget http://packages.linuxdeepin.com/deepin/pool/main/d/deepin-scrot/deepin-scrot_2.0-0 ...
  • Flashloader程式主要是用來將你的Application下載進i.MXRT支持的所有外部非易失性存儲器中,為後續從外部存儲器啟動做準備。BootROM只有啟動Application功能,沒有下載更新Application功能,而Flashloader最核心的就是下載更新Application... ...
  • 環境 centos:7.2 JDK:1.8 Flume:1.8 一、Flume 安裝 1) 下載 wget http://mirrors.tuna.tsinghua.edu.cn/apache/flume/1.8.0/apache-flume-1.8.0-bin.tar.gz 2) 解壓 tar – ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...