当前位置:网站首页>Flashback Technology of Oracle Database
Flashback Technology of Oracle Database
2022-08-02 13:12:00 【Aoki and the Wind】
当 Oracle When a logical corruption of the database occurs,Database recovery can be performed simply and quickly using flashback technology.
Flashback Database uses flashback logs to perform flashbacks.Flashback deletes using the Recycle Bin.All other techniques use restore data.并不
Yes all flashback functions modify the database.Some functions are just methods for querying past versions of data
一、闪回数据库
使用闪回数据库,By reverting all changes that have occurred since some previous point in time,Databases can be quickly restored to the past
state at a certain point in time.When using the Flashback Database feature,No need to restore backups.The Flashback Database feature can be handy
Undo changes that caused logical data corruption.In the event of media loss or physical damage to the database,must use traditional methods
行恢复.
1. How to configure Flashback Database
SQL>shutdown immediate;
SQL>startup mount exclusive;
SQL>alter system set db_flashback_retention_terget=2880 scope=both;
SQL>alter system set DB_RECOVERY_FILE_DEST_SIZE=20G scope=both;
SQL>alter system set db_recovery_file_dest='+FRA' scope=both;
SQL>alter database flashback on;
SQL>alter database open;
注意:DB_FLASHBACK_RETENTION_TARGET The initialization parameter is used to set the retention target,Database can be specified
The upper limit of flashback(以分钟为单位).This parameter is just a target,No guarantee is provided,Flashback time interval depends
The amount of data stored in the flashback log in the fast recovery area.
Query to confirm whether Flashback Database is enabled:
SQL>select flashback_on from v$database;
2. Flashback database method
Flashback Database must start with EXCLUSIVE Schema loading can be performed FLASHBACK DATABASE 命令,And when it's done
必须使用 RESETLOGS 选项打开数据库.
在使用 RMAN 命令 FLASHBACK DATABASE When the command performs a Flashback Database operation,可以使用 SEQUENCE
和 THREAD Specify the redo log sequence number and thread number as the lower bound,RMAN Only select the serial number that can be used to flash back to the specified(但
Does not include the specified serial number)的文件.
也可以使用 FLASHBACK DATABASE 的 SQL command to restore a database to a time in the past or SCN. 如果
使用 TO SCN 子句,A number must be provided.如果指定 TO TIMESTAMP, A timestamp must be provided
值.You can also specify a restore point name,例如:
RMAN> FLASHBACK DATABASE TO TIME="TO_DATE('2013-05-27 09:00:00',
'YYYY-MM-DD HH24:MI:SS')";
RMAN> FLASHBACK DATABASE TO SCN=23565;
RMAN> FLASHBACK DATABASE TO SEQUENCE=223 THREAD=1;
或者:
SQL> FLASHBACK DATABASE TO TIMESTAMP(SYSDATE-1/24);
SQL> FLASHBACK DATABASE TO SCN 53943;
SQL> FLASHBACK DATABASE TO RESTORE POINT b4_load;
3. Flashback Database test
This section of the lab tests timestamp-based database flashbacks.
1) Create a test table for experimentation hr.t_obj:
SQL>create table hr.t_obj as select * from dba_objiects;
SQL>select count(*) from hr.t_obj;
2) 获取当前系统时间:
SQL>select to_char(sysdate, 'yyyy-mm-dd hh24:mi:ss') tm from dual;
3) 删除 hr Users and their objects:
SQL>drop user hr cascade;
SQL>select count(*) from hr.t_obj;
4) 建立对照表
SQL>select count(*) from system.tab1;
5) Perform Flashback Database operations,恢复 hr
SQL>shutdown immediate;
SQL>startup mount;
SQL>flashback database to timestamp to_timestamp
2 ('2014-11-03 10:48:48','yyyy-mm-dd hh24:mi:ss');
SQL>alter database open resetlogs;
6) 验证
SQL>select count(*) from hr.t_obj;
SQL>select count(*) from system tab1;
可以看到,Changes up to the time stamp of Flashback Database are reverted,Changes made after that are no longer valid.因此,闪回
The database is the overall fallback to the database.
二、The delete flashback of the table
表删除(drop)The principle of flashback is to use the recycle bin technology,Deleted objects are temporarily placed in the recycle bin and still belong to it
所有者.When a dropped table is moved to the recycle bin,The table and its associated objects and constraints are renamed with a system-generated name.
The recycle bin itself is also a data dictionary table,It is used to maintain the relationship between the original name of the deleted object and its system-generated name.
使用 DBA_RECYCLEBIN, USER_RECYCLEBIN Views query the contents of the recycle bin.
To use the flashback delete function,必须将 FLASHBACK TABLE 或 FLASHBACK ANY TABLE 系统权限授予
Users who use the Flashback Table feature.此外,还必须将 SELECT, INSERT, DELETE 和 ALTER 对象权限授予
用户.
1. Delete flashback syntax for tables
FLASHBACK TABLE table_name TO BEFORE DROP [RENAME TO new_name];
2. A delete flashback test for a table
1) 删除 hr.t_obj 表:
SQL>conn hr/hr
SQL>select count(*) from hr.t_obj;
SQL>drop table hr.t_obj;
SQL>select count(*) from hr.t_obj;
2) Query the recycle bin and perform flashback delete:
SQL>select object_name, original_name, can_undrop, base_object
2 from user_recyclebin;
SQL>flashback table hr.t_obj to before drop;
SQL>select count(*) from hr.t_obj;
三、闪回查询
Flashback queries are typically used to retrieve all historical versions of a record,Backtracks individual transactions or backtracks to a particular time since the specified time
All changes to the schedule.
1. Flashback query syntax
SELECT <column_name_list> FROM <table_name>
AS OF <SCN> --- 使用 as of scn
或 AS OF <TIMESTAMP> --- 使用 as of timestamp
[WHERE <filter_conditions>]
[GROUP BY <unaggregated columns>]
[HAVING <group_filter>]
[ORDER BY <column_positions_or_name>]
2. Flashback query test
1) Create a test table for experimentation tab1:
SQL>create table hr.tab1 as select user_id, username from dba_users where 1=0;
SQL>insert into hr.tab1 select user_id, username from dba_users where user_id < 10;
SQL>commit;
SQLselect * from hr.tab1;
2) 对表进行删除操作,and do a flashback query:
SQL>conn hr/hr;
SQL>select to_char(sysdate, 'yyyy-mm-dd hh24:mi:ss') tm from dual;
SQL>delect tab1 where username='SYS';
SQL>select * from tab1;
SQL>seelct *from tab1 as of timestamp to_timestamp ('2022-08-01 11:00:00', 'yyyy-mm-dd hh24:mi:ss');
四、闪回表
1. Table flashback method
A prerequisite for using Flashback Table is that row migration for the table must be enabled:
ALTER TABLE schema_name.table_name ENABLE ROW MOVEMENT;
Syntax for table flashback:
FLASHBACK TABLE schema_name.table_name TO SCN <scn_number>
-- 基于 SCN The table flashes back
或 TO TIMESTAMP <timestamp> -- 基于 TIMESTAMP The table flashes back
或 TO RESTORE POINT <restore_point> -- 基于 RESTORE POINT The table flashes back
[<ENABLE | DISABLE> TRIGGERS]
2. Table flashback test
本节实验基于 RESTORE POINT The table flashes back.
基于 RESTORE POINT A table flashback starts with creating an appropriate restore point,The syntax for creating a restore point is :
CREATE RESTORE POINT point_name;
Useless flashback points can be deleted in time after the flashback is successful,The syntax for deleting a flashback point is :
DROP RESTORE POINT point_name;
1) Create a test table for Flashback Table hr.tab2,and create a restore point p1:
SQL>create table hr.tab2 as select user_id, username from dba_users where 1 = 0;
SQL>alter table hr.tab2 enanle row movement;
SQL>insert into hr.tab2 seelct user_id, username from dba_users where user_id < 10;
SQL>select * from hr.tab2;
SQL>create restore point p1;
2) 对表 hr.tab2 进行插入操作,and create a restore point p2:
SQL>insert into hr.tab2 select user_id, username from dba_users
2 where user_id >= 10 and user_id < 20;
SQL> select * from hr.tab2;
SQL>select * from hr.tab2;
SQL>create restore point p2;
3) 从表 hr.tab2 进行删除,创建还原点 p3:
SQL>delect hr.tab2 where user_id = 5;
SQL>seelct * from hr.tab2;
SQL>create restore point p3;
4) Start the Flashback Table operation:
SQL>flashback table hr.tab2 to restore point p1;
SQL>select * from hr.tab2;
SQL>flashback table hr.tab2 to restore point p2;
SQL>select * from hr.tab;
SQL>flashback table hr.tab2 to restore point p3;
SQL>select * from hr.tab2;
5) 删除还原点:
SQL>fdrop restore point p1;
SQL>drop restore point p2;
SQL>drop restore point p3;
五、闪回版本查询
The Flashback Versions query refers to Oracle For a specific object, you can query all the changes of the object within a specific period of time
况,The object can also be modified to a specific moment according to specific needs.
闪回版本查询同闪回查询、闪回表一样,都是使用了 UNDO 段的数据,That is, a historical copy of data changes,
当 UNDO After a segment's data has been purged due to space changes,则无法进行闪回.
1. 闪回版本查询语法
SELECT <columns> FROM <schema_name.table_name>
VERSIONS BETWEEN SCN <minimum_scn> AND <maximum_scn>
-- 基于 SCN 的版本查询
或者:
SELECT <columns> FROM <schema_name.table_name>
VERSIONS BETWEEN timestamp
to_timestamp('start_timestamp') and to_timestamp('end_timestamp')
-- 基于 TIMESTAMP 的版本查询
2. Flashback version query test
Use the test table created by the flashback table query in the previous lesson hr.tab2:
SQL>col USER_ID format 99999
SQL>col USERNAME format a10
SQL>seelct user_ID, username, versions_xid, versions_startscn,
2 versions_endscn, versions_operation
3 from hr.tab2 versions between scn minvalue and maxvalue;
其中:
versions_xid - Records the unique identifier of the transaction for the specified version.
versions_startscn - 记录的起始 SCN 号.
versions_endscn -- Termination of records SCN 号.
versions_operation - The type of operation that was logged(I 表示插入,U 表示更新,D 表示删除).
Flashback Transaction Query is an extension to Flashback Version Query.从某种程度上来说,Flashback Versions queries are typically used for more fine-grained
查询,Such as for a specific record.A flashback transaction is a flashback for a transaction,is based on the transaction level.flashback
Service queries are made through the query view flashback_transaction_query to obtain one or more specific transaction information,
Also available under this view undo_sql statement in the column to reverse the transaction,从而保证数据的完整性.
To use flashback transaction query,Supplemental logging must be enabled and the correct permissions established.例如,To flash the table on the previous section
Manipulate the created test table tab2 Use flashback transactions,就要以 SYSDBA 权限在 SQL*Plus Execute the following settings
setting steps:
SQL>alter database add supplemental log data;
SQL>alter database add supplemental log data (primary key) columns;
SQL>grant execute on dbms_flashback to hr;
SQL>grant select any transaction to hr;
然后对 hr.tab2 进行增删改操作,Then follow the hex line ID A flashback transaction query is made:
边栏推荐
猜你喜欢
随机推荐
LeetCode_377_Combination Sum IV
FreeRTOS experiment -- delete task
“二舅”火了,自媒体短视频“爆火”的基本要素,你知道吗?
水平垂直居中方式
Object.entries()
动态组件-component
瀑布流式布局怎么实现(什么是瀑布流布局)
Four seasons of trees realized by svg
Detailed explanation of network flow (what information can the flow network diagram generally reflect)
How to use the database like tap water?|Tencent Cloud Database TDSQL-C
最小割和对偶图(未完成)
【C语言】夏日一题 —— 如何判断素数?
【C语言】手把手带你写游戏 —— 猜数字
自动生成代码器推荐-code-gen
你知道图论的Dijkstra吗?
鲁大师7月新机性能/流畅榜:骁龙8+正面对决天玑9000+,性能跑分突破123万!
鲁大师7月新机性能/流畅榜:性能跑分突破123万!
网络流详解(流网图一般能够反映什么信息)
ThinkPHP 5.1反序列化分析和poc
什么是 commonjs2