一、清理日常备份的数据表
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技术专栏