123
返回列表 发新帖
楼主: qfsb_p

大量的insert/update/delete操作后,进行select超慢

[复制链接]
论坛徽章:
0
21#
发表于 2004-9-18 20:15 | 只看该作者
最初由 loveandluck 发布
[B]也可能是因为开始有大量数据,高水位标记值很高。再去select时仍要扫描大量的数据块。 [/B]

应该就是这个原因了
已经delete之后,hwm值保持不变,整个表的extents很大,select时候当然会慢拉
不信可以看看dba_segments中的bytes值是不是很大
当然,也可以使用sys.dbms_space.free_blocks分析一下你这个表在hwm下有多少free_blocks

使用道具 举报

回复
论坛徽章:
0
22#
发表于 2004-12-13 21:02 | 只看该作者

我也来灌一下水

如果很多表都经常DELETE的话,就最好对所有的导出再导入一下,如果只是这个表比较经常DELETE,那就先CREATA BALE TABLE_TMP AS SLECT *  FROM TABLENAME;
TRUNCATE TABLE TABLENAME;
INSERT INTO TABLENAME SELECT * FROM TABLE_TMP;
COMMIT;
DROP TABLE TABLE_TMP;

使用道具 举报

回复
论坛徽章:
0
23#
发表于 2004-12-14 00:04 | 只看该作者
在大量的update/insert/delete之后,不仅hwm会增加,碎片增加,索引的叶结点会增加很多,产生大量碎片,在select时自然会很慢,建议分析一下索引。如果结点很多,请重建索引。

使用道具 举报

回复

您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

TOP技术积分榜 社区积分榜 徽章 团队 统计 知识索引树 积分竞拍 文本模式 帮助
  ITPUB首页 | ITPUB论坛 | 数据库技术 | 企业信息化 | 开发技术 | 微软技术 | 软件工程与项目管理 | IBM技术园地 | 行业纵向讨论 | IT招聘 | IT文档
  ChinaUnix | ChinaUnix博客 | ChinaUnix论坛
CopyRight 1999-2011 itpub.net All Right Reserved. 北京盛拓优讯信息技术有限公司版权所有 联系我们 未成年人举报专区 
京ICP备16024965号-8  北京市公安局海淀分局网监中心备案编号:11010802021510 广播电视节目制作经营许可证:编号(京)字第1149号
  
快速回复 返回顶部 返回列表