oracle清理日常备份数据及恢复误删除表
2014-08-21 11:47
453 查看
一、清理日常备份的数据表
1、背景:系统表空间占用率已经超过90%。于是做了一个相关的垃圾数据进行清理的工作。
2、查询需清理表清单:因为日常在数据库操作的时候,经常会进行一些表的备份。咨询前任系统管理员,他们在备份表的时候一般是在原表上加日期或者使用bak进行标识。于是使用
3、测试:在测试系统中将已经初步确定的表进行删除,进行相关业务的测试。没有问题。
4、正式操作:依照公司的变更流程,对正式系统进行操作;
二、误删除表的恢复
在做完一的工作之后,业务运行了2天无故障,第三天的时候,财务报修说财务合并报表自动抵消项生成分录少一项。分析后确定是误删除了一张报表使用到的数据表。需要对该表进行恢复。
恢复的代码如下:
确定问题解决。
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 使用DBMS_FLASHBACK恢复意外删除的数据
- oracle rman 备份和还原 恢复数据库
- oracle 备份数据库 恢复数据库(导入已备份的数据) 用户级别
- Oracle+sde数据备份、恢复
- Oracle 备份、恢复表空间数据步骤
- 【总结】oracle恢复误删除数据,解除锁定的等sql语句
- 意外删除Oracle数据文件(dbf),恢复oralce库的解决办法--Oracle错误代码:ORA-01033
- 在没有备份情况下误删除数据文件的恢复
- Oracle+sde数据备份、恢复
- Oracle备份、恢复单表或多表数据
- 利用RMAN备份恢复ORACLE数据
- 【总结】oracle恢复误删除数据,解除锁定的等sql语句
- 系统损坏,移植Oracle(9.2.0.1)数据库(无备份数据文件进行恢复)
- 使用oracle闪回查询功能恢复之前删除的数据
- Oracle 数据导入和导出(备份和恢复) 常用命令
- Oracle中删除表,删除数据以及恢复数据
- ORACLE误删除数据的恢复方法
- [强烈推荐]Oracle:只有rman备份(数据,参数,日志,控制文件全丢失)的恢复
- oracle 快速恢复表删除的某行数据