查询和删除数据表中反复数据的sql

1、查询表中反复数据。

select * from people
查询及删除反复记录的方法大全where peopleId in (select   peopleId   from   people   group   by   peopleId   having   count(peopleId) > 1)
查询及删除反复记录的方法大全
查询及删除反复记录的方法大全2、删除表中多余的反复记录,反复记录是依据单个字段(peopleId)来推断。仅仅留有rowid最小的记录
查询及删除反复记录的方法大全delete from people 
查询及删除反复记录的方法大全where peopleId   in (select   peopleId   from people   group   by   peopleId    having   count(peopleId) > 1)
查询及删除反复记录的方法大全and rowid not in (select min(rowid) from   people   group by peopleId   having count(peopleId )>1)
查询及删除反复记录的方法大全
查询及删除反复记录的方法大全3、查找表中多余的反复记录(多个字段) 

查询及删除反复记录的方法大全elect * from vitae a
查询及删除反复记录的方法大全where (a.peopleId,a.seq) in   (select peopleId,seq from vitae group by peopleId,seq   having count(*) > 1)
查询及删除反复记录的方法大全
查询及删除反复记录的方法大全4、删除表中多余的反复记录(多个字段),仅仅留有rowid最小的记录
查询及删除反复记录的方法大全delete from vitae a
查询及删除反复记录的方法大全where (a.peopleId,a.seq) in   (select peopleId,seq from vitae group by peopleId,seq having count(*) > 1)
查询及删除反复记录的方法大全and rowid not in (select min(rowid) from vitae group by peopleId,seq having count(*)>1)
查询及删除反复记录的方法大全
查询及删除反复记录的方法大全
查询及删除反复记录的方法大全5、查找表中多余的反复记录(多个字段)。不包括rowid最小的记录
查询及删除反复记录的方法大全select * from vitae a
查询及删除反复记录的方法大全where (a.peopleId,a.seq) in   (select peopleId,seq from vitae group by peopleId,seq having count(*) > 1)
查询及删除反复记录的方法大全and rowid not in (select min(rowid) from vitae group by peopleId,seq having count(*)>1)
查询及删除反复记录的方法大全
查询及删除反复记录的方法大全(二)
查询及删除反复记录的方法大全例如说
查询及删除反复记录的方法大全在A表中存在一个字段“name”,
查询及删除反复记录的方法大全并且不同记录之间的“name”值有可能会同样,
查询及删除反复记录的方法大全如今就是须要查询出在该表中的各记录之间,“name”值存在反复的项;
查询及删除反复记录的方法大全Select Name,Count(*) From A Group By Name Having Count(*) > 1
查询及删除反复记录的方法大全
查询及删除反复记录的方法大全假设还查性别也同样大则例如以下:
查询及删除反复记录的方法大全Select Name,sex,Count(*) From A Group By Name,sex Having Count(*) > 1
查询及删除反复记录的方法大全
查询及删除反复记录的方法大全
查询及删除反复记录的方法大全(三)
查询及删除反复记录的方法大全方法一
查询及删除反复记录的方法大全
查询及删除反复记录的方法大全declare @max integer,@id integer
查询及删除反复记录的方法大全
查询及删除反复记录的方法大全declare cur_rows cursor local for select 主字段,count(*) from 表名 group by 主字段 having count(*) >。 1
查询及删除反复记录的方法大全
查询及删除反复记录的方法大全open cur_rows
查询及删除反复记录的方法大全
查询及删除反复记录的方法大全fetch cur_rows into @id,@max
查询及删除反复记录的方法大全
查询及删除反复记录的方法大全while @@fetch_status=0
查询及删除反复记录的方法大全
查询及删除反复记录的方法大全begin
查询及删除反复记录的方法大全
查询及删除反复记录的方法大全select @max = @max -1
查询及删除反复记录的方法大全
查询及删除反复记录的方法大全set rowcount @max
查询及删除反复记录的方法大全
查询及删除反复记录的方法大全delete from 表名 where 主字段 = @id
查询及删除反复记录的方法大全
查询及删除反复记录的方法大全fetch cur_rows into @id,@max
查询及删除反复记录的方法大全
查询及删除反复记录的方法大全end
查询及删除反复记录的方法大全
查询及删除反复记录的方法大全close cur_rows
查询及删除反复记录的方法大全
查询及删除反复记录的方法大全set rowcount 0
查询及删除反复记录的方法大全
方法二
查询及删除反复记录的方法大全
"反复记录"有两个意义上的反复记录,一是全然反复的记录,也即全部字段均反复的记录,二是部分keyword段反复的记录。比方Name字段反复,而其它字段不一定反复或都反复能够忽略。
查询及删除反复记录的方法大全
查询及删除反复记录的方法大全  1、对于第一种反复,比較easy解决。使用
查询及删除反复记录的方法大全
查询及删除反复记录的方法大全select distinct * from tableName
查询及删除反复记录的方法大全
查询及删除反复记录的方法大全  就能够得到无反复记录的结果集。
查询及删除反复记录的方法大全
查询及删除反复记录的方法大全  假设该表须要删除反复的记录(反复记录保留1条)。能够按下面方法删除
查询及删除反复记录的方法大全
查询及删除反复记录的方法大全select distinct * into #Tmp from tableName
查询及删除反复记录的方法大全
查询及删除反复记录的方法大全drop table tableName
查询及删除反复记录的方法大全
查询及删除反复记录的方法大全select * into tableName from #Tmp
查询及删除反复记录的方法大全
查询及删除反复记录的方法大全drop table #Tmp
查询及删除反复记录的方法大全
查询及删除反复记录的方法大全  发生这样的反复的原因是表设计不周产生的,添加唯一索引列就可以解决。


查询及删除反复记录的方法大全
查询及删除反复记录的方法大全  2、这类反复问题通常要求保留反复记录中的第一条记录,操作方法例如以下
查询及删除反复记录的方法大全
查询及删除反复记录的方法大全  如果有反复的字段为Name,Address。要求得到这两个字段唯一的结果集
查询及删除反复记录的方法大全
查询及删除反复记录的方法大全select identity(int,1,1) as autoID, * into #Tmp from tableName
查询及删除反复记录的方法大全
查询及删除反复记录的方法大全select min(autoID) as autoID into #Tmp2 from #Tmp group by Name,autoID
查询及删除反复记录的方法大全
查询及删除反复记录的方法大全select * from #Tmp where autoID in(select autoID from #tmp2)
查询及删除反复记录的方法大全
查询及删除反复记录的方法大全  最后一个select即得到了Name,Address不反复的结果集(但多了一个autoID字段。实际写时能够写在select子句中省去此列)
查询及删除反复记录的方法大全
查询及删除反复记录的方法大全(四)
查询及删除反复记录的方法大全查询反复
查询及删除反复记录的方法大全
查询及删除反复记录的方法大全select * from tablename where id in (select id from tablename group by id 
查询及删除反复记录的方法大全
查询及删除反复记录的方法大全having count(id) > 1)

原文地址:https://www.cnblogs.com/brucemengbm/p/7111855.html