Oracle表碎片起因及解决办法

2014-11-24 18:06:18 · 作者: · 浏览: 0

今天发现在一个SQL查询用不到索引,classid是建了索引的,如下:
select * from infobase where classid in(10001,10002,10003,10004,10005);
奇怪的发现在classid in(10001,10002)的值两以上就用不索引,两个以下就可以用到,开始怀疑是索引有问题,于是就重建下了下classid上的索引还是不行。从网上找到一篇文章才知道可能是表中存在碎片的问题
于是用下面的步骤解决:
1、重建表:
create table infobase2 select * from infobase;
2、改以前的表名:
alter table infobase rename to infobase3;
3、改新建表名为以前表名:
alter table infobase2 rename to infobase;
4、建上索引:
create index classid_ind on infobase(classid);


可是过了一天问题又出现了,索引又是不能使用了,然后执行下面的语句解决:
ANALYZE TABLE INFOBASE compute Statistics;
或是
ANALYZE TABLE INFOBASE estimate STATISTICS SAMPLE 50 PERCENT ;
--注意:50 PERCENT 值太小索引可能还是不起作用,我就开始用20 PERCENT 时,索引还是用不上。


行链接(Row chaining) 与行迁移(Row Migration)
当一行的数据过长而不能插入一个单个数据块中时,可能发生两种事情:行链接(row chaining)或行迁移(row migration)。