当前位置: 代码迷 >> Oracle开发 >> 一个delete语句暴慢无比,怎么优化
  详细解决方案

一个delete语句暴慢无比,怎么优化

热度:64   发布时间:2016-04-24 07:19:39.0
一个delete语句暴慢无比,如何优化?
delete from tbl_survey where n_id not in (select max(n_id) from tbl_survey group by n_human_id)

n_id是主键,n_human_id是人的编码,数字类型,表中有重复,已经建了normal索引。

表中一共60000多条数据,其中n_human_id重复的大概30000条。

这个查询运行了10多分钟都没有出结果,如果我强制加上n_id<10000这样的限制的话,即使只是删除2000条数据,大概也要跑5分钟左右。

实在不知道问题出在哪里?数据库服务器性能没有问题,cpu和内存都在50%以下。





------解决方案--------------------
--一个表只判断一列重复 现在是empno重复--最高效----
DELETE FROM EMP E WHERE E.ROWID > (SELECT MIN(X.ROWID)
FROM EMP X WHERE X.EMP_NO = E.EMP_NO);

------解决方案--------------------
delete * from tbl_survey t1 where where t1.n_id!= 
(select max(n_id) from tbl_survey t2 
where t1.n_human_id=t2.n_human_id) 

不要用group by
  相关解决方案