• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    oracle误删数据表还原的二种方法(oracle还原)

    一、如果是刚刚删除,那么有两方法:

    首先用show parameter undo;命令查看当时的数据库参数undo_retention设置。

    显示如下:

    复制代码 代码如下:

    undo_management   string   AUTO

    undo_retention  integer 10800

    undo_suppress_errors  boolean  FALSE

    undo_tablespace   string   UNDOTBS1

    undo_retention(保持力),10800单位是秒。即3个小时。

    修改默认的undo_retention参数设置:

    复制代码 代码如下:

    ALTER SYSTEM SET undo_retention=10800 SCOPE=BOTH;

    方法1,通过oracle提供的回闪功能:

    复制代码 代码如下:

    exec dbms_flashback.enable_at_time(to_date('2007-07-23 10:21:00','yyyy-mm-dd hh24:mi:ss'));

    set serveroutput on

    DECLARE r_temp hr.job_history%ROWTYPE;

    CURSOR c_temp IS SELECT * FROM hr.job_history;

    BEGIN

    OPEN c_temp;

    dbms_flashback.disable;

    LOOP

    FETCH c_temp INTO r_temp;

    EXIT WHEN c_temp%NOTFOUND;

    insert into hr.job_history(EMPLOYEE_ID,JOB_ID,START_DATE,END_DATE) values (r_temp.EMPLOYEE_ID,r_temp.JOB_ID,r_temp.START_DATE,r_temp.END_DATE);

    commit;

    END LOOP;

    CLOSE c_temp;

    END;

    方法2,insert into hr.job_history

    复制代码 代码如下:

    select * from hr.job_history as of timestamp to_timestamp('2007-07-23 10:20:00', 'yyyy-mm-dd hh24:mi:ss');

    这种方法简单,容易掌握,功能和上面的一样时间为你误操作之前的时间,最好是离误操作比较近的,因为oracle保存在回滚保持段里的数据时间有一定的时间限制由undo_retention 这个参数值决定。

    二、如果是删除一段时间了,但你有比较新的数据库备份,就通过备份来恢复。新建一个库,把备份还原上去,导出表数据,再导入到现在用的库中去。

    三、如果删除一段时间了,并且无备份,但是数据在写入表的时候同时会写入其它一些关联表的话,那么就尝试通过写SQL语句从其它表取数据出来insert到被删除的表中。

    四、恢复到备份表中

    复制代码 代码如下:

    create table tableName_bak
    as
    select * from tableName as of TIMESTAMP to_timestamp('20081126 103435','yyyymmdd hh24miss');

    您可能感兴趣的文章:
    • Oracle的数据表中行转列与列转行的操作实例讲解
    • Oracle 创建用户及数据表的方法
    • Oracle 数据表分区的策略
    • Oracle对两个数据表交集的查询
    • 如何将Oracle的一个大数据表快速迁移到 Sqlserver2008数据库(图文教程)
    上一篇:在Tomcat服务器下使用连接池连接Oracle数据库
    下一篇:修改计算机名或IP后Oracle10g服务无法启动的解决方法
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

    oracle误删数据表还原的二种方法(oracle还原) oracle,误删,数据表,还原,