当前位置: 首页 > news >正文

oracle 闪回恢复

oracle 闪回恢复
闪回恢复区主要通过3个初始化参数来设置和管理:
db_recovery_file_dest:指定闪回恢复区的位置
db_recovery_file_dest_size:指定闪回恢复区的可用空间大小
db_flashback_retention_target:指定数据库可以回退的时间,单位为分钟,默认1440分钟,也就是一天

默认值是1440,单位是minute,即24 小时,需要注意的是该参数虽然未直接指定flash recovery area大小,但却受其制约,举个例子假如数据库每天有10%左右的数据变动的话,如果该初始化参数值设置为1440,则flash recovery area 的大小至少要是当前数据库实际容量的10%,如果该初始化参数设置为2880,则flash recovery area 的大小就至少是数据库所占容量的20%。
闪回也受undo_retention的限制默认是900 15分钟

启用闪回:
首先要启用归档日志 archivelog list;
startup mount ;
alter database flashback on;
select FLASHBACK_ON from v$database;查看闪回是否开启
alter database flashback off; 关闭闪回

select file_type from v $flash_recovery_area_usage; 放到闪回恢复区的内容
select * from v $flash_recovery_area_usage;或者 select * from v $ recovery_file_dest;来查看恢复区的使用情况,如果归档日志存放再次目录且没有空闲数据库会hang住

闪回包括:Flashback Database, Flashback Drop,Flashback Query(分Flashback Query,Flashback Version Query, Flashback Transaction Query 三种) 和Flashback Table。
Flashback Database 功能非常类似与RMAN的不完全恢复, 它可以把整个数据库回退到过去的某个时点的状态, 这个功能依赖于Flashback log 日志。 比RMAN更快速和高效。 因此Flashback Database 可以看作是不完全恢复的替代技术。 但它也有某些限制:

  1. Flashback Database 不能解决Media Failure, 这种错误RMAN恢复仍是唯一选择
  2. 如果删除了数据文件或者利用Shrink技术缩小数据文件大小,这时不能用Flashback Database技术回退到改变之前的状态,这时候就必须先利用RMAN把删除之前或者缩小之前的文件备份restore 出来, 然后利用Flashback Database 执行剩下的Flashback Datbase。
  3. 如果控制文件是从备份中恢复出来的,或者是重建的控制文件,也不能使用Flashback Database。
  4. 使用Flashback Database锁能恢复到的最早的SCN, 取决与Flashback Log中记录的最早SCN。

Flashback Database
可以建一个表在每次重要操作的时候记录scn
create table test (id int,comments varchar2(20),times date);
insert into test1 values((select current_scn from v$database),‘test’,sysdate); 重要操作前
该操作需要在mount状态下
在这里插入图片描述
Flashback Drop
该操作是有recyclebin来实现回滚
drop table name purge;(如果加上purge就直接删除不会进入回收站)
show parameter recycle
select *from recyclebin 会看到你的drop操作
在这里插入图片描述
Flashback Query
select * from xxx as of timestamp|scn
alter session set nls_date_format=‘YYYY-MM-DD hh24:mi:ss’;
select * from test1 as of timestamp sysdate-2/1440;(查询几分钟之内的数据)
select * from test1 as of timestamp to_timestamp(‘2023-05-17 15:10:00’,‘YYYY-MM-DD hh24:mi:ss’)(指定时间内的之前的数据)
在这里插入图片描述
也可以使用insert into A select * from A as of scn 1095782; 使用scn来进行恢复
或者直接恢复表flashback table emp_test to timestamp to_timestamp(‘2013/11/21 23:14:59’,‘yyyy-mm-dd hh24:mi:ss’); or flashback table emp_test to scn 2701570;

Flashback Transaction Query
SELECT xid, start_timestamp, operation, table_name, undo_sql
FROM flashback_transaction_query
WHERE table_name = ‘your_table_name’
AND operation IN (‘INSERT’, ‘UPDATE’, ‘DELETE’);

FLASHBACK TRANSACTION ‘’ TO BEFORE COMMIT;

该语句查询oracle数据库实际的大小
select sum(GB) as "TOTAL(G)"from (select sum(bytes)/1024/1024/1024 as GBfrom dba_data_filesunion allselect sum(bytes)/1024/1024/1024from dba_temp_filesunion allselect sum(bytes)/1024/1024/1024from v$log);```
http://www.lryc.cn/news/69188.html

相关文章:

  • LeetCode 322 零钱兑换
  • 面试篇SpringMVC是什么以及工作原理
  • jQuery-层级选择器
  • 【Java数据结构】——第十节(下).选择排序与堆排序
  • 45道SQL题目陆续更新
  • 在线PS软件有哪些不错的推荐
  • Java实现天气预报功能
  • python循环语句
  • 多线程基础(一)线程基础信息、synchronized 锁概念
  • JAVA期末考内容知识点的梳理
  • 为什么要使用Thrift与Protocol Buffers?
  • oa是什么意思?oa系统哪个好用?
  • Linq和C# Lambda表达式
  • 蓝桥:前端开发笔面必刷题——Day2 数组(三)
  • 人工智能专栏第四讲——人工智能的未来展望与机遇
  • Unity阴影(Shadow)、Shadowmap
  • 编程语言的四种错误处理方法,你知道几种?
  • ContOS7单机安装Hadoop
  • 抓取动态网页的数据的具体操作方法
  • Windows 和 Linux 环境下 ProtoBuf 的安装
  • 商用密码应用安全性测评方案编制流程
  • Elasticsearch 集群部署插件管理及副本分片概念介绍
  • Liunx 套接字编程(2)TCP接口通信程序
  • 8年开发经验,浅谈 API 管理
  • 【软考备战·四月模考】希赛网四月模考软件设计师上午题
  • MySQL中的@i:=@i+1用法详解
  • web安全第一天 ,域名,dns
  • 【Linux】Linux编辑神器vim的使用
  • vulnhub渗透测试靶场练习1
  • Uart,RS232,RS485串口通讯协议学习