Oracle 删除重复数据

Oracle 删除重复数据只留一条,查询及删除重复记录的SQL语句
 
1、查找表中多余的重复记录,重复记录是根据单个字段(Id)来判断 
 

1 select * fromwhere Id in (select Id fromgroup by Id having count(Id) > 1)


2、删除表中多余的重复记录,重复记录是根据单个字段(Id)来判断,只留有rowid最小的记录
 

1 DELETE from2 WHERE (id) IN ( SELECT id FROMGROUP BY id HAVING COUNT(id) > 1) AND ROWID NOT IN (SELECT MIN(ROWID) FROM3 GROUP BY id 

4 HAVING COUNT(*) > 1);


3、查找表中多余的重复记录(多个字段) 
 

1 select * from 表 a where (a.Id,a.seq) in(select Id,seq fromgroup by Id,seq having count(*) > 1)


4、删除表中多余的重复记录(多个字段),只留有rowid最小的记录
 

1 delete from 表 a 

2 where (a.Id,a.seq) in 

3 (select Id,seq fromgroup by Id,seq having count(*) > 1) and rowid not in (select min(rowid) fromgroup by Id,seq having count(*)>1)


5、查找表中多余的重复记录(多个字段),不包含rowid最小的记录 
 

1 select * from 表 a 

2 where (a.Id,a.seq) in 

3 (select Id,seq fromgroup by Id,seq having count(*) > 1) and rowid not in (select min(rowid) fromgroup by Id,seq having count(*)>1)

 


原文链接

你可能感兴趣的:(oracle)