假如你治理的Oracle数据库下某些应用项目有大量的修改删除操作, 数据索引是需要周期性的重建的.
它不仅可以提高查询性能, 还能增加索引表空间空闲空间大小.
在ORACLE里大量删除记录后, 表和索引里占用的数据块空间并没有释放.
重建索引可以释放已删除记录索引占用的数据块空间.
转移数据, 重命名的方法可以重新组织表里的数据.
下面是可以按ORACLE用户名生成重建索引的SQL脚本:
SET ECHOOFF;
SET FEEDBACKOFF;
SET VERIFYOFF;
SET PAGESIZE0;
SET TERMOUT ON;
SET HEADING OFF;
ACCEPT username CHAR PROMPT 'Enter the index username: ';
spool /oracle/rebuild_&username.sql;
当删除的比率大于15 - 20% 时,肯定是需要索引重建的.
经过删改后的rebuild_&username.sql文件我们可以放到ORACLE的定时作业里:
比如一个月或者两个月在非繁忙时间运行.
假如碰到ORA-00054错误, 表示索引在的表上有锁信息, 不能重建索引.
那就忽略这个错误, 看下次是否成功.
对那些非凡忙的表要区别对待, 不能用这里介绍的方法, 还要把它们的索引从rebuild_&username.sql里删去.