折雨的天空

博客介绍:本博客当前共有文章【968】篇,总阅读量【5,176,934】次,第一篇博客发表于【2011年04月06日 10时34分】,距今已【4990】天,感谢您的使用!

您的位置:折雨的天空 >其他技术> Oracle表删除大量数据后查询变慢问题

Oracle表删除大量数据后查询变慢问题

原文地址:


http://zhouchaofei2010.iteye.com/blog/1754739


备份:



Oracle 表删除大量数据后,即使表中只有几行记录,但用select count(*) from table 来查询发觉都不会马上出来,原因是该表的空间大了,查询起来很慢。解决的方法是把该表所占用的表空间缩小,或者说释放表空间。
alter table XXXX move; 这样处理后就释放了表空间了。但是释放表空间后,表的行号rowid会发生变化,而基于rowid的索引则会变成无效。因此该操作后必须重建索引。否则会 提示“ORA-01502: 索引'SMP.ITEMLOG_MID_IDX'或这类索引的分区处于不可用状态” 而重建索引的方法当然可以先drop掉再create ,但是这样太麻烦了,用alter index XXX rebuild 这样最快了,不会改变原来的索引结构。

作者“迈小步、不停步!”



然后,可以使用语句:




select 'alter table ' || table_name || ' move;' from user_tables;

这样的来生成SQL语句,然后复制过去直接执行就好了。


更新索引的语句:


select 'alter index ' || index_name || ' rebuild;' from user_indexes;


------------正 文 已 结 束, 感 谢 您 的 阅 读 (折雨的天空)--------------------

转载请注明本文标题和链接:《Oracle表删除大量数据后查询变慢问题

奖励一下

取消

分享不易,烦请有多多打赏,如您也困难,点击右边关闭即可!

扫码支持
扫码打赏,5元,10元,你说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

-秒后自动关闭,如已打赏,或者不愿打赏,请点击右上角关闭图标。

发表评论

路人甲 表情
看不清楚?点图切换