zoukankan      html  css  js  c++  java
  • Oracle 如何恢复删除并提交的表数据

    在Oracle的数据库中,如果不小心删除数据,该如何恢复数据呢?

    有两种方法 :scn 方法和时间戳方法

    一、恢复删除数据的SQL语法(建议用时间戳)

    1、通过scn恢复删除且已提交的数据

    1)获得当前数据库的scn号

        select current_scn from v$database; (切换到sys用户或system用户查询) 

        查询到的scn号为:1499223

    2)查询当前scn号之前的scn

        select * from 表名 as of scn 1499220; (确定删除的数据是否存在,如果存在,则恢复数据;如果不是,则继续缩小scn号)

    3)恢复删除且已提交的数据

        flashback table 表名 to scn 1499220;

    2、通过时间恢复删除且已提交的数据

    1)查询当前系统时间

     select to_char(sysdate,'yyyy-mm-dd hh24:mi:ss') from dual;

    2)查询删除数据的时间点的数据

     select * from 表名 as of timestamp to_timestamp('2018-10-09 15:29:00','yyyy-mm-dd hh24:mi:ss');  (如果不是,则继续缩小范围)

    3)恢复删除且已提交的数据

      --开启行移动功能(解决执行以下语句报错问题)

      alter table 表名 enable row movement;

    --恢复某个时间点的数据

       flashback table 表名 to timestamp to_timestamp('2018-10-09 15:29:00','yyyy-mm-dd hh24:mi:ss');

    --关闭行移动功能

      alter table 表名 disable row movement;

    二、恢复删除数据的实例(方法)

    1、查询删除数据前表数据

    --查询删除前表的数据---
    select * from Dxc_Goods;

    2、执行删除数据操作(132,133),并查看

    --执行删除操作:132,133--
    delete from Dxc_GOODS where MID in(132,133);
    --提交(模拟误删操作)
    commit;

    查看结果

    3、恢复删除并提交的数据 (指定删除时间点,保证这个是执行删除之前的时间)

      --开启行移动功能(解决执行以下语句报错问题)
      alter table Dxc_Goods enable row movement;
      --恢复某个时间点的数据
       flashback table Dxc_Goods to timestamp to_timestamp('2019-07-24 18:00:00','yyyy-mm-dd hh24:mi:ss');
      --关闭行移动功能
      alter table Dxc_Goods disable row movement;

    执行后,查询数据(132,133数据已恢复)

    PS:

    参考网址:https://blog.csdn.net/qq_36460189/article/details/82983732

  • 相关阅读:
    关于课内外读物的建议
    c# Aes加解密
    web api 如何通过接收文件流的方式,接收客户端及前端上传的文件
    c# 文件夹权限
    mysql 8创建远程访问用户以及连接mysql速度慢的解决方法
    为什么读书?读书让我们明心见性!
    大部分教程不会告诉你的 12 个 JS 技巧
    nuget包管理nuget服务器发布包时出现请求报错 406 (Not Acceptable)
    Python 实现毫秒级淘宝、京东、天猫等秒杀抢购脚本
    eos的资源和工具列表
  • 原文地址:https://www.cnblogs.com/xielong/p/11239939.html
Copyright © 2011-2022 走看看