1. 如何开启数据库闪回?

SQL> shutdown immediate;

ORA-01109: database not open

Database dismounted.

ORACLE instance shut down.

SQL> startup mount;

ORACLE instance started.

Total System Global Area 1653518336 bytes

Fixed Size                  2253784 bytes

Variable Size            1207962664 bytes

Database Buffers          436207616 bytes

Redo Buffers                7094272 bytes

Database mounted.

SQL> alter database flashback on;--------------------------在mout情况下开启闪回.

Database altered.

SQL> select flashback_on from v$database;------------------到v$database视图中查询闪回是否开启

FLASHBACK_ON

------------------

YES

SQL>

  1. 数据库的闪回
    1. 基于SCN的闪回

SCN是数据库的顺序号,每个号都是数据库的一个状态,当知道具体的SCN号的时候就可以精确地闪回,可以通过日志来查看具体的SCN

SQL>flashback database to scn 5540916;

  1. 基于时间的闪回

如果知道大概的时间,也可以通过时间闪回

Flashback database to '2:05 PM';

  • 需要性能开销、闪回日志磁盘空间的开销
  • 默认数据库的闪回技术是关闭的,建议开启.
  1. 表的闪回
    1. 删除表的闪回

SQL> conn test/test

Connected.

SQL> select * from w;

X

----------

1

SQL> drop table w;--------------------------------------------删除表,没有加purge参数,这时候表会放到回收站

Table dropped.

SQL> select * from w;

select * from w

*

ERROR at line 1:

ORA-00942: table or view does not exist

SQL> show recyclebin;-----------------------------------------------------查看回收站

ORIGINAL NAME    RECYCLEBIN NAME                OBJECT TYPE DROP TIME

---------------- ------------------------------ ------------ -------------------

W                BIN$UgO0wwwhHBTgU3ABqMDCXQ==$0 TABLE        2017-06-16:01:07:40

SQL> flashback table w to before drop;--------------------------------使用flashback技术还原w表

Flashback complete.

SQL> select * from w;

X

----------

1

SQL> drop table w purge;--------------------------如果使用了purge表示表已经在回收站同时删除了,就不能恢复了

Table dropped.

SQL> show recyclebin;

  1. DML操作的闪回

做了一个操作,并且提交了怎么办?

SQL> select rowid,id,name from g;

ROWID                      ID NAME

------------------ ---------- ----------

AAAVW7AAEAAAAD8AAC          1 a

AAAVW7AAEAAAAD8AAD          2 b

SQL> select sysdate 时间, timestamp_to_scn(sysdate) SCN from dual;----------------------将系统时间转换为scn号

时间                      SCN

------------------ ----------

16-JUN-17             1373003

SQL> delete from g where id=2;

1 row deleted.

SQL> commit;

Commit complete.

SQL> select rowid,id,name from g;

ROWID                      ID NAME

------------------ ---------- ----------

AAAVW7AAEAAAAD8AAC          1 a

SQL> alter table g enable row movement;-----------因为恢复了就不是以前那个位置了,所以flashback需要允许行迁移,在flashback中使用,当需要使用flashback table功能时,需要首先打开row movement的选项,否则使用该功能也会报错

Table altered.

SQL> flashback table g to scn 1373003;

Flashback complete.

SQL> select rowid,id,name from g;--------------------注意rowid已经不一样了

ROWID                      ID NAME

------------------ ---------- ----------

AAAVW7AAEAAAAD8AAA          1 a

AAAVW7AAEAAAAD8AAB          2 b

  1. 事务的闪回
  2. 版本的闪回
  3. 查询的闪回
    1. 基于时间的查询闪回

Select * from g as of timestamp sysdate-5/1440-----------当前时间-5,这里表示5分钟之前

  1. 基于SCN的查询闪回

Select * from g as of scn 344197

Oracle 的闪回技术 --flashback的更多相关文章

  1. SQL Fundamentals: 表的创建和管理(表的基本操作,闪回技术flashback,表结构修改)

    SQL Fundamentals || Oracle SQL语言 1.表的基本操作 (CREATE TABLE, DROP TABLE,TRUNCATE TABLE, RENAME tablename ...

  2. Oracle闪回技术(Flashback)

    闪回技术有闪回表.闪回删除.闪回查询.闪回事务查询.闪回事务.闪回数据库.闪回数据归档.其中,闪回查询.闪回事务查询用来“观察”过去:闪回数据归档并不是一个独立的功能,其功能是扩展闪回查询的时间窗口: ...

  3. Oracle 六闪回技术,flashback

    Flashback 技术基于Undo segment基于内容的, 因此,限制UNDO_RETENTON参数. 要使用flashback 特征,您必须启用自己主动撤销管理表空间. 在Oracle 11g ...

  4. 【Oracle】闪回技术

    1.闪回技术描述 2.数据库的准备: --undo表空间要设置成AUTO,设置合适的保存时间.undo表空间: SYS@ENMOEDU> show parameter undo NAME TYP ...

  5. Oracle的闪回技术--闪回错误的DML操作

    提交DML操作后,该操作使用的还原段就可以被其它对象使用了,为了保证闪回操作时这些数据仍然被保存在还原段中,可能需要重新设置undo_retention参数,表示一个事务提交后,该事务的数据必须保存在 ...

  6. Oracle的闪回技术--闪回已删除的表

    注意闪回技术只能保护非系统表决空间中的表,而且表空间必须本地管理, 外键将不可以被恢复, 索引和约束的名字将会被命名为以BIN开头,由系统生成的名字 查看是否开启闪回: SQL> show pa ...

  7. Oracle Flashback Technology【闪回技术】

    -------------------------与其他数据库相比,Oracle的闪回让开发者多了一条选择的路. Flashback的目的 先看下Oracle官方文档中的解释: Oracle Flas ...

  8. Oracle闪回技术详解

     概述: 闪回技术是Oracle强大数据库备份恢复机制的一部分,在数据库发生逻辑错误的时候,闪回技术能提供快速且最小损失的恢复(多数闪回功能都能在数据库联机状态下完成).需要注意的是,闪回技术旨在快速 ...

  9. Oracle 闪回特性(FLASHBACK DATABASE)

    --===================================== -- Oracle 闪回特性(FLASHBACK DATABASE) --======================= ...

随机推荐

  1. FFMPEG的解码后的数据格式

    这两天在阅读电视转发服务器中的流媒体底层库的源码时,在看到显示部分的时候,遇到了一些疑问: 就是在用d3d做显示时候,我们显示的数据格式,指定为yv12,对于YV12的数据格式在内存中的分布,可以参考 ...

  2. (转)MFC:Windows如何区分鼠标双击和两次单击

    在Windows平台上,鼠标左键的按下.松开.快速的两次点击会产生WM_LBUTTONDOWN.WM_LBUTTONUP和WM_LBUTTONDBLCLK消息,但是Windows根据什么来区分连续的两 ...

  3. linux下安装dovecot

    Dovecot是一个开源的,为Linux/Unix-like系统提供IMAP,POP3服务的软件.主要是为了安全产生的,不管大小应用,Dovecot都是一个非常优秀的选择.它非常快,配置简单,不需要专 ...

  4. 【Java面试题】13 Anonymous Inner Class (匿名内部类) 是否可以extends(继承)其它类,是否可以implements(实现)interface(接口)?

    1.什么是匿名内部类? 内部类,存在于另一个类内部的类,而匿名内部类,顾名思义,就是没有名字的内部类. 2.为什么需要匿名内部类? 每个inner class都能够各自继承某一实现类(implemen ...

  5. jquery-创建元素和添加子元素

    一.创建新元素 1.使用$函数创建新元素 var $newElement=$('<div><p>段落</p></div>');//创建元素,返回jQue ...

  6. c++ String 大小写转化

    string toUpperString(string str) { transform(str.begin(), str.end(), str.begin(), (int (*)(int))toup ...

  7. java web 复选框checked

    熟悉web前端开发的人都知道,判断复选框是否选中是经常做的事情,判断的方法很多,但是开发过程中常常忽略了这些方法的兼容性,而是实现效果就好了.博主之前用户不少方法,经常Google到一些这个不好那个不 ...

  8. 网页中Span和Div的区别

    它们被用来组合一大块的HTML代码并赋予一定的信息,大部分用类属性class和标识属性id与元素联系起来,见CSS中级指南的类和id选择符. span和div的不同之处在于span是内联的,用在一小块 ...

  9. ASP.NET自带对象JSON字符串与实体类的转换

    关于JSON的更多介绍,请各位自行google了解!如果要我写的话,我也是去Google后copy!嘿嘿,一直以来很想学习json,大量的找资料和写demo,总算有点了解! 切入正题! 还是先封装一个 ...

  10. redis配置密码认证,通过密码可以进行连接

    需求说明: 今天配置了一台redis服务器,想要也和其他的数据库一样配置用户名/密码的方式进行登录. 查找了一下,没看到配置用户名的地方,就是有认证密码,所以就做了测试,在此进行记录. 操作过程: 1 ...