SQLServer去重复查询,不删除重复数据
SQLServer使用select进行查询时去重,除了使用distinct,group+ROW_NUMBER()这两种还有别的方式吗?...
SQLServer使用select进行查询时去重,除了使用distinct,group+ROW_NUMBER()这两种还有别的方式吗?
展开
展开全部
1、要有定位基准,也就是说,你的表必需要有一个不重复的键值,如果没有,请你给这个表加一个字段,将这个字段设为自增变量字段,建议为int类型,比如字段名可为“编码”。
2、查重复的数据:
select *from 表名 where 编码 in
(select 编码 from 表名 group by 编码 having count(1) >= 2)
3、删除所有有重复的记录:
delete from 表名 where
编码 in(select 编码 from 表名 group by 编码 having count(1) >= 2)
4、删去重复的,只留下重复记录中编码最大的一条:
delete from 表名 where
编码 in(select 编码 from 表名 group by 编码 having count(1) >= 2)
and 编码 not in (select max(编码)from 表名 group by 编码 having count(1) >=2)
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询