https://docs.oracle.com/en/database/oracle/oracle-database/tutorial-rec-flashback/index.html?opt-release-19c?learningpath=true&appuser=nobody&appsession=9331452079823&contentid=26524&activityname=Recover%20a%20Dropped%20Table%20Using%20Oracle%20Flashback%20Drop&eventid=6362
Recover a Dropped Table Using Oracle Flashback Drop
Background
Oracle Flashback Drop enables you to reverse the effects of dropping (deleting) a table, returning the dropped table to the database along with dependent objects such as indexes and triggers. This feature stores dropped objects in a recycle bin, from which they can be retrieved until the recycle bin is purged, either explicitly or because space is needed.
Create a New Table
In this section you create a new table.
- Invoke SQL*Plus and connect as the SYSTEM user.
- Alter session to pluggable database container orclpdb.
# SQL> alter session set container=orclpdb; Session altered.
- Create a new table named
HR.REGIONS_HIST
. Use the following statement to create a table that has the same structure and content as theHR.REGIONS
table.SQL>create table hr.regions_hist as select * from hr.regions; Table created.
- Query the new
HR.REGIONS_HIST
table.SQL>select * from hr.regions_hist; REGION_ID REGION_NAME ---------- ------------------------- 1 Europe 2 Americas 3 Asia 4 Middle East and Africa
Drop a Table
In this section you drop your new HR.REGIONS_HIST
table.
- Execute the
DROP TABLE
command to drop the table.SQL>drop table hr.regions_hist; Table dropped.
- Query the
HR.REGIONS_HIST
table.SQL>select * from hr.regions_hist; select * from hr.regions_hist * ERROR at line 1: ORA-00942: table or view does not exist
Notice that you get an error because the table is dropped.
Recover the Dropped Table
In this section you recover the HR.REGIONS_HIST
table from the recycle bin.
- Execute the
FLASHBACK TABLE
command to recover the dropped table.SQL>flashback table hr.regions_hist to before drop; Flashback complete.
- Once again query the
HR.REGIONS_HIST
table to verify the data has been restored.SQL>select * from hr.regions_hist; REGION_ID REGION_NAME ---------- ------------------------- 1 Europe 2 Americas 3 Asia 4 Middle East and Africa
- Exit from SQL*Plus.
No comments:
Post a Comment