• 爱情文章
  • 亲情文章
  • 友情文章
  • 生活随笔
  • 校园文章
  • 经典文章
  • 人生哲理
  • 励志文章
  • 搞笑文章
  • 心情日记
  • 英语文章
  • 范文大全
  • 作文大全
  • 新闻阅读
  • 当前位置: 山茶花美文网 > 生活随笔 > 正文

    [oracle清理日常备份数据及恢复误删除表]oracle备份数据

    时间:2020-05-27来源:山茶花美文网 本文已影响 山茶花美文网手机站

    一、清理日常备份的数据表

    1、背景:系统表空间占用率已经超过90%。于是做了一个相关的垃圾数据进行清理的工作。

    2、查询需清理表清单:因为日常在数据库操作的时候,经常会进行一些表的备份。咨询前任系统管理员,他们在备份表的时候一般是在原表上加日期或者使用bak进行标识。于是使用

    SELECT owner, num_rows * avg_row_len,table_name FROM DBA_TABLES WHERE TABLE_NAME LIKE "%BAK%" AND REGEXP_LIKE(TABLE_NAME,"/d+") AND (TABLE_NAME NOT LIKE "T_IM_INVENTORY%" AND TABLE_NAME NOT LIKE "VT%" AND TABLE_NAME NOT LIKE "NCM%" AND TABLE_NAME NOT LIKE "T_HR_SCHM%" AND TABLE_NAME NOT LIKE "SYS%" AND OWNER="JINGYA");

    查询出相关可能性的表占用的空间,排除其他可能表之后,合计占用空间接近100G。

    3、测试:在测试系统中将已经初步确定的表进行删除,进行相关业务的测试。没有问题。

    4、正式操作:依照公司的变更流程,对正式系统进行操作;

    二、误删除表的恢复

    在做完一的工作之后,业务运行了2天无故障,第三天的时候,财务报修说财务合并报表自动抵消项生成分录少一项。分析后确定是误删除了一张报表使用到的数据表。需要对该表进行恢复。

    恢复的代码如下:

    --1 从闪回中查询误drop的表select object_name, original_name, partition_name, type, ts_name, createtime, droptime from recyclebin where original_name = "T_CSL_ITEMDATAENTRY001"; --2 恢复到删除前flashback table "BIN$AP6V8ohdAaLgU8CoZGEBog==$0" to before drop; --3 查询数据select count(*) from T_CSL_ITEMDATAENTRY001

    确定问题解决。

    • [oracle清理日常备份数据及恢复误删除表]oracle备份数据 相关文章:
    • 爱情文章
    • 亲情文章
    • 友情文章
    • 随笔
    • 哲理
    • 励志
    • 范文大全