45fan.com - 路饭网

搜索: 您的位置主页 > 网络频道 > 阅读资讯:SQL之查询重复记录的方法

SQL之查询重复记录的方法

2016-08-31 16:42:26 来源:www.45fan.com 【

SQL之查询重复记录的方法

(一)
SQL之查询重复记录的方法
1
、查找表中多余的重复记录,重复记录是根据单个字段(peopleId)来判断
SQL之查询重复记录的方法
select*from
people
SQL之查询重复记录的方法
wherepeopleIdin(selectpeopleIdfrompeoplegroupbypeopleIdhavingcount(peopleId)>1
)
SQL之查询重复记录的方法
SQL之查询重复记录的方法
2
、删除表中多余的重复记录,重复记录是根据单个字段(peopleId)来判断,只留有rowid最小的记录
SQL之查询重复记录的方法
deletefrom
people
SQL之查询重复记录的方法
wherepeopleIdin(selectpeopleIdfrompeoplegroupbypeopleIdhavingcount(peopleId)>1
)
SQL之查询重复记录的方法
androwidnotin(selectmin(rowid)frompeoplegroupbypeopleIdhavingcount(peopleId)>1
)
SQL之查询重复记录的方法
SQL之查询重复记录的方法
3
、查找表中多余的重复记录(多个字段)
SQL之查询重复记录的方法
select*from
vitaea
SQL之查询重复记录的方法
where(a.peopleId,a.seq)in(selectpeopleId,seqfromvitaegroupbypeopleId,seqhavingcount(*)>1
)
SQL之查询重复记录的方法
SQL之查询重复记录的方法
4
、删除表中多余的重复记录(多个字段),只留有rowid最小的记录
SQL之查询重复记录的方法
deletefrom
vitaea
SQL之查询重复记录的方法
where(a.peopleId,a.seq)in(selectpeopleId,seqfromvitaegroupbypeopleId,seqhavingcount(*)>1
)
SQL之查询重复记录的方法
androwidnotin(selectmin(rowid)fromvitaegroupbypeopleId,seqhavingcount(*)>1
)
SQL之查询重复记录的方法
SQL之查询重复记录的方法
SQL之查询重复记录的方法
5
、查找表中多余的重复记录(多个字段),不包含rowid最小的记录
SQL之查询重复记录的方法
select*from
vitaea
SQL之查询重复记录的方法
where(a.peopleId,a.seq)in(selectpeopleId,seqfromvitaegroupbypeopleId,seqhavingcount(*)>1
)
SQL之查询重复记录的方法
androwidnotin(selectmin(rowid)fromvitaegroupbypeopleId,seqhavingcount(*)>1
)
SQL之查询重复记录的方法
SQL之查询重复记录的方法(二)
SQL之查询重复记录的方法比方说
SQL之查询重复记录的方法在A表中存在一个字段“name”,
SQL之查询重复记录的方法而且不同记录之间的“name”值有可能会相同,
SQL之查询重复记录的方法现在就是需要查询出在该表中的各记录之间,“name”值存在重复的项;
SQL之查询重复记录的方法
SelectName,Count(*)FromAGroupByNameHavingCount(*)>1

SQL之查询重复记录的方法
SQL之查询重复记录的方法如果还查性别也相同大则如下:
SQL之查询重复记录的方法
SelectName,sex,Count(*)FromAGroupByName,sexHavingCount(*)>1
SQL之查询重复记录的方法
SQL之查询重复记录的方法
SQL之查询重复记录的方法(三)
SQL之查询重复记录的方法方法一
SQL之查询重复记录的方法
SQL之查询重复记录的方法
declare@maxinteger,@idinteger
SQL之查询重复记录的方法
SQL之查询重复记录的方法
declarecur_rowscursorlocalforselect主字段,count(*)from表名groupby主字段havingcount(*)>1
SQL之查询重复记录的方法
SQL之查询重复记录的方法
opencur_rows
SQL之查询重复记录的方法
SQL之查询重复记录的方法
fetchcur_rowsinto@id,@max

SQL之查询重复记录的方法
SQL之查询重复记录的方法
while@@fetch_status=0
SQL之查询重复记录的方法
SQL之查询重复记录的方法
begin
SQL之查询重复记录的方法
SQL之查询重复记录的方法
select@max=@max-1
SQL之查询重复记录的方法
SQL之查询重复记录的方法
setrowcount@max
SQL之查询重复记录的方法
SQL之查询重复记录的方法
deletefrom表名where主字段=@id
SQL之查询重复记录的方法
SQL之查询重复记录的方法
fetchcur_rowsinto@id,@max
SQL之查询重复记录的方法
SQL之查询重复记录的方法
end
SQL之查询重复记录的方法
SQL之查询重复记录的方法
closecur_rows
SQL之查询重复记录的方法
SQL之查询重复记录的方法
setrowcount0

SQL之查询重复记录的方法
SQL之查询重复记录的方法方法二
SQL之查询重复记录的方法
SQL之查询重复记录的方法有两个意义上的重复记录,一是完全重复的记录,也即所有字段均重复的记录,二是部分关键字段重复的记录,比如Name字段重复,而其他字段不一定重复或都重复可以忽略。
SQL之查询重复记录的方法
SQL之查询重复记录的方法
1、对于第一种重复,比较容易解决,使用
SQL之查询重复记录的方法
SQL之查询重复记录的方法
selectdistinct*from
tableName
SQL之查询重复记录的方法
SQL之查询重复记录的方法就可以得到无重复记录的结果集。
SQL之查询重复记录的方法
SQL之查询重复记录的方法如果该表需要删除重复的记录(重复记录保留1条),可以按以下方法删除
SQL之查询重复记录的方法
SQL之查询重复记录的方法
selectdistinct*into#Tmpfrom
tableName
SQL之查询重复记录的方法
SQL之查询重复记录的方法
droptable
tableName
SQL之查询重复记录的方法
SQL之查询重复记录的方法
select*intotableNamefrom
#Tmp
SQL之查询重复记录的方法
SQL之查询重复记录的方法
droptable
#Tmp
SQL之查询重复记录的方法
SQL之查询重复记录的方法发生这种重复的原因是表设计不周产生的,增加唯一索引列即可解决。
SQL之查询重复记录的方法
SQL之查询重复记录的方法
2
、这类重复问题通常要求保留重复记录中的第一条记录,操作方法如下
SQL之查询重复记录的方法
SQL之查询重复记录的方法假设有重复的字段为Name,Address,要求得到这两个字段唯一的结果集
SQL之查询重复记录的方法
SQL之查询重复记录的方法
selectidentity(int,1,1)asautoID,*into#Tmpfrom
tableName
SQL之查询重复记录的方法
SQL之查询重复记录的方法
selectmin(autoID)asautoIDinto#Tmp2from#Tmpgroupby
Name,autoID
SQL之查询重复记录的方法
SQL之查询重复记录的方法
select*from#TmpwhereautoIDin(selectautoIDfrom
#tmp2)
SQL之查询重复记录的方法
SQL之查询重复记录的方法最后一个select即得到了Name,Address不重复的结果集(但多了一个autoID字段,实际写时可以写在select子句中省去此列)
SQL之查询重复记录的方法
SQL之查询重复记录的方法(四)
SQL之查询重复记录的方法查询重复
SQL之查询重复记录的方法
SQL之查询重复记录的方法
select*fromtablenamewhereidin
(
SQL之查询重复记录的方法
SQL之查询重复记录的方法
selectidfrom
tablename
SQL之查询重复记录的方法
SQL之查询重复记录的方法
groupby
id
SQL之查询重复记录的方法
SQL之查询重复记录的方法
havingcount(id)>1

SQL之查询重复记录的方法
SQL之查询重复记录的方法)
 

本文地址:http://www.45fan.com/a/question/70398.html
Tags: sql 重复 记录
编辑:路饭网
关于我们 | 联系我们 | 友情链接 | 网站地图 | Sitemap | App | 返回顶部