免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 5233 | 回复: 5
打印 上一主题 下一主题

[请问]表数据很大,删除其中一些数据很慢,如何优化?谢谢 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2004-07-14 15:45 |只看该作者 |倒序浏览

delete from 表名
where (字段A>;=:变量1 and 字段A < 200000000)
or 字段A >;=:变量2;

字段A上有重复索引

有什么好的办法删除数据吗?或者对以上语句优化

有人建议用/*+parallel(table_name n)*/ 不知道是否有效?

请各位帮忙

论坛徽章:
0
2 [报告]
发表于 2004-07-21 19:40 |只看该作者

[请问]表数据很大,删除其中一些数据很慢,如何优化?谢谢

delete太慢,而且删除纪录后表空间并未释放,表的高水位依然很高,导致应用效率低下,最好这么做:
1、create table newtable as select * from oldtable
     where (字段A<:变量1 or 字段A >;= 200000000)
                and 字段A <:变量2;
2、drop table oldtable;
3、rename newtable to oldtable;
4、create index ..................;

论坛徽章:
0
3 [报告]
发表于 2004-07-21 19:59 |只看该作者

[请问]表数据很大,删除其中一些数据很慢,如何优化?谢谢

那样的话create index要很久的,好像不行的

论坛徽章:
0
4 [报告]
发表于 2004-07-29 10:35 |只看该作者

[请问]表数据很大,删除其中一些数据很慢,如何优化?谢谢

先用不含数据的exp旧表,再对旧表换名,再imp旧表,再tranc 新表重置高位,再insert into 新表 select * from 旧表 where ..........
这样速度很快,也不用重建index。

论坛徽章:
0
5 [报告]
发表于 2004-11-02 11:26 |只看该作者

[请问]表数据很大,删除其中一些数据很慢,如何优化?谢谢

原帖由 "lmhcn" 发表:
先用不含数据的exp旧表,再对旧表换名,再imp旧表,再tranc 新表重置高位,再insert into 新表 select * from 旧表 where ..........
这样速度很快,也不用重建index。


lmhcn兄:
“tranc 新表重置高位“是什么意思

论坛徽章:
0
6 [报告]
发表于 2004-11-07 17:41 |只看该作者

[请问]表数据很大,删除其中一些数据很慢,如何优化?谢谢

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

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP