- 如何删除oracle库中相同的记录,但是保留重复记录中的一条记录:
- 解决方法:可以利用oracle中的rowid伪列来达到这个目的:
-
- 1.建立临时表,并将查询到的重复数据插入其中(是否可以建一个视图?):
- create table temp_woods as
- (select item_id,count(*) as rowcount from wooods group by item_id having count(*) > 1 );
-
- 2.查询相同的纪录:
- select a.*,a.rowid from woods a where a.rowid <> (select max(b.rowid) from woods b where b.item_id in (select item_id from temp_woods) where b.item_id = a.item_id) ;
-
- 3.删除重复的记录并保留其中rowid列最大的纪录:
- delete from woods a where a.rowid <> (select max(b.rowid) from woods b where b.item_id in (select item_id from temp_woods) where b.item_id = a.item_id) ;
-
- 4.删除临时表:
- drop table temp_woods cascade constraints ;
来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/28878983/viewspace-2133898/,如需转载,请注明出处,否则将追究法律责任。
转载于:http://blog.itpub.net/28878983/viewspace-2133898/