简要咨询咨询QQ网站导航网站搜索手机站点联系我们设为首页加入收藏 

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

来源:易贤网   阅读:744 次  日期:2014-10-17 09:18:16

温馨提示:易贤网小编为您整理了“oracle清理日常备份数据及恢复误删除表”,方便广大网友查阅!

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

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

确定问题解决。

更多信息请查看IT技术专栏

更多信息请查看数据库
点此处就本文及相关问题在本站进行非正式的简要咨询(便捷快速)】     【点此处查询各地各类考试咨询QQ号码及交流群
上一篇:Oracle中存储过程执行大的Sql语句时如何查看sql是否正确
下一篇:ORACLE毫秒与日期的相互转换
易贤网手机网站地址:oracle清理日常备份数据及恢复误删除表
由于各方面情况的不断调整与变化,易贤网提供的所有考试信息和咨询回复仅供参考,敬请考生以权威部门公布的正式信息和咨询为准!