使用 FLASH DATABASE 恢復誤刪除的用戶

来源:http://www.cnblogs.com/tinazzz/archive/2017/06/25/7076161.html
-Advertisement-
Play Games

場景描述 誤 drop 了生產庫中的用戶 U1 U1 用戶下麵有 3 張表(T1 T3),表中數據如下所示: 前期準備 第一步,查詢 v$log、v$archived_log中每個日誌的 First SCN/ First Time 和 Next SCN/Next Time,根據時間推測該刪除操作會在 ...


場景描述

  • 誤 drop 了生產庫中的用戶 U1
  • U1 用戶下麵有 3 張表(T1-T3),表中數據如下所示:
SQL> conn u1/u1
Connected.
SQL> select TABLE_NAME from user_tables;

TABLE_NAME
------------------------------
T1
T2
T3

SQL> select * from t1;

    ID NAME
---------- --------------------
     2 xyz

SQL> select * from t2;

    ID
----------
    10

SQL> select * from t3;

    ID LAST_NAME        FIRST_NAME
---------- -------------------- --------------------
     1 Zhang        lili
     2 li           lei

前期準備

  • 第一步,查詢 v$log、v$archived_log中每個日誌的 First SCN/ First Time 和 Next SCN/Next Time,根據時間推測該刪除操作會在哪個日誌中
  • 第二步,使用 Toad 挖掘日誌( 因為刪除一個用戶,會先刪除用戶下的所有對象,然後再刪除用戶,所以要找到刪除屬於它的對象的最早的 SCN,在本例中應選擇 1794239)


執行閃回

  • 環境描述
    • 生產庫的版本是 11.2.0.4,搭建了 Data Guard,備庫啟用了閃回特性
    • 在備庫執行閃回操作
  • 1)停止 Redo Apply
SQL> alter database recover managed standby database cancel;

Database altered.
  • 如果不停止 Redo Apply 的話,在執行閃回時會報錯
SQL> FLASHBACK DATABASE TO SCN 1794239;
FLASHBACK DATABASE TO SCN 1794239
*
ERROR at line 1:
ORA-01153: an incompatible media recovery is active
  • 2)閃回資料庫
SQL> FLASHBACK DATABASE TO SCN 1794239;

Flashback complete.
  • 3)查看用戶相關信息,確認用戶是否已經恢復
  • 4)在備庫使用 exp 導出用戶數據(無法使用數據泵技術,因為備庫的模式是 read only,所以使用了 exp 導出數據)
exp system/oracle owner=u1 file=/tmp/test.dump
  • 5)需要在主庫建立用戶 U1 並授權
    • 如果不建立用戶,在導入的時候會報錯(ORA-01435: user does not exist)
    • 如果不授權,在導入的時候會報錯(ORA-01950: no privileges on tablespace 'USERS')
SQL> create user u1 identified by "123abc";

SQL> grant connect,resource to u1;
  • 6)在備庫連接主庫 orcl,然後導入文件
[oracle@db11gstandby ~]$ imp system/oracle@orcl file=/tmp/test.dump full=y

Import: Release 11.2.0.4.0 - Production on Wed Jun 21 19:32:17 2017

Copyright (c) 1982, 2011, Oracle and/or its affiliates.  All rights reserved.


Connected to: Oracle Database 11g Enterprise Edition Release 11.2.0.4.0 - 64bit Production
With the Partitioning, OLAP, Data Mining and Real Application Testing options

Export file created by EXPORT:V11.02.00 via conventional path
import done in AL32UTF8 character set and AL16UTF16 NCHAR character set
. importing SYSTEM's objects into SYSTEM
. importing U1's objects into U1
. . importing table                           "T1"          1 rows imported
. . importing table                           "T2"          1 rows imported
. . importing table                           "T3"          2 rows imported
Import terminated successfully without warnings.
  • 7)註意:在閃回操作完成後,開啟 Redo Apply,此時備庫又可以與主庫同步

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

-Advertisement-
Play Games
更多相關文章
  • 前端性能優化的方法? content方面 1,減少HTTP請求:合併文件、CSS精靈、inline Image 2,減少DNS查詢:DNS查詢完成之前瀏覽器不能從這個主機下載任何任何文件。方法:DNS緩存、將資源分佈到恰當數量的主機名,平衡並行下載和DNS查詢 3,避免重定向:多餘的中間訪問 4,使 ...
  • 學習前端有一段時間了,一直在看書上的理論知識,而實戰項目卻很少。師兄常說,想要知道自己的實力有多少,知識掌握了多少,最好的方法就是去實踐了,實踐出真知嘛。於是決定在這個假期里,主要是通過項目的實踐以及理論知識的輔助來提高代碼水平。首先是做幾個HTML5+CSS3靜態頁面佈局的練習,查缺補漏知識點並且 ...
  • vue的事件: vue事件簡寫: vue中事件是 v-on:click=' show()' 但是我嫌棄它寫太長每次動 v-on: 事件 vue中就有事件簡寫 @click='show()' 這會不會就好點了呢!<!DOCTYPE html> vue的事件對象: vue中當然也有事件對象了 , 這樣@ ...
  • animation-timging-function 主要是控制css動畫從開始到結束的速度。 linear:線性過渡。等同於貝塞爾曲線(0.0, 0.0, 1.0, 1.0)ease:平滑過渡。等同於貝塞爾曲線(0.25, 0.1, 0.25, 1.0)ease-in:由慢到快。等同於貝塞爾曲線( ...
  • 一句話概括的話:閉包就是一個函數,捕獲作用域內的外部綁定。 官方的定義:一個擁有許多變數和綁定了這些變數的環境的表達式(通常是一個函數),因為這些變數也稱為該表達式的一部分。 自由變數和閉包的關係:自由變數閉合於閉包的創建。 內部邏輯就是 自由變數:如果一個函數內部有其他函數,那麼這些內部函數可以訪 ...
  • Swiper(Swiper master)是目前應用較廣泛的移動端網頁觸摸內容滑動js插件,可以用來做輪播和滑動. 初始化 <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title></title> <link rel="styleshe ...
  • 作者:Antonio Leiva 時間:Jun 20, 2017 原文鏈接:https://antonioleiva.com/objects-kotlin/ Kotlin對象是Android開發人員不熟悉的另一個語言元素,因為在Java中沒有這樣的東西。 事實上,對象就是具有單一實現的數據類型。所以 ...
  • 以下代碼是一個顯示圖片的RecyclerView 的Adapter用到的,當點擊圖片,跳到另一個Activity顯示大圖。RecyclerView 與ListView不同 然而沒有setOnClickListener() 方法, 設置事件監聽, 使用下麵的方式。點擊後獲取到圖片url 傳遞給另一個a ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...