您好,登錄后才能下訂單哦!
這篇文章主要為大家展示了“如何使用RMAN對CDB執行閃回數據庫操作”,內容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領大家一起研究并學習一下“如何使用RMAN對CDB執行閃回數據庫操作”這篇文章吧。
對CDB執行閃回數據庫與對non-CDB執行閃回數據庫操作是類似的,具體操作步驟如下:
1.使用SQL*Plus連接到目標數據庫來判斷閃回操作的的目標SCN,還原點或時間點
SQL> SELECT OLDEST_FLASHBACK_SCN, OLDEST_FLASHBACK_TIME FROM V$FLASHBACK_DATABASE_LOG; OLDEST_FLASHBACK_SCN OLDEST_FLASH -------------------- ------------ 5090113 17-DEC-17 SQL> SELECT CURRENT_SCN FROM V$DATABASE; CURRENT_SCN ----------- 6003920
2.刪除表t1中的數據
SQL> select count(*) from t1; COUNT(*) ---------- 39 SQL> delete from t1; 39 rows deleted. SQL> commit; Commit complete.
3.關閉數據庫,并確保沒有任何實例打開數據庫,然后啟動到mount狀態
SQL> shutdown immediate Database closed. Database dismounted. ORACLE instance shut down. SQL> startup mount ORACLE instance started. Total System Global Area 6442450944 bytes Fixed Size 8807168 bytes Variable Size 1895828736 bytes Database Buffers 4529848320 bytes Redo Buffers 7966720 bytes Database mounted.
4.運行flashback database命令將整個CDB閃回到指定的時間點
SQL> flashback database to scn 6003920; Flashback complete.
5.在SQL*Plus命令窗口中將CDB設置為只讀狀態
SQL> alter database open read only; Database altered.
6.如果閃回操作后滿足你所要求的結果,那么可以執行以下兩個相互排斥的選項:
.使用resetlogs選項將數據庫打開。如果當前數據庫為只讀狀態,那么使用SQL*Plus執行以下命令:
shutdown immediate startup mount alter database open resetlogs
.使用Oracle Data Pump導出你所需要的對象,然后使用RMAN來恢復數據庫到當前時間,通過對數據庫重新應用重做日志中的所有改變來將
數據庫恢復到當前時間點從而撤消閃回數據庫所做的改變。
RMAN> recover database; Starting recover at 18-DEC-17 allocated channel: ORA_DISK_1 channel ORA_DISK_1: SID=11 instance=jy1 device type=DISK starting media recovery media recovery complete, elapsed time: 00:00:02 Finished recover at 18-DEC-17 Media recovery complete. SQL> alter database open; Database altered. SQL> alter pluggable database all open read write; Pluggable database altered.
以上是“如何使用RMAN對CDB執行閃回數據庫操作”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。