SQLServer去重复查询,不删除重复数据

SQLServer使用select进行查询时去重,除了使用distinct,group+ROW_NUMBER()这两种还有别的方式吗?... SQLServer使用select进行查询时去重,除了使用distinct,group+ROW_NUMBER()这两种还有别的方式吗? 展开
 我来答
琴旧可1
2019-09-03 · TA获得超过3621个赞
知道大有可为答主
回答量:4881
采纳率:85%
帮助的人:229万
展开全部


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)



推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式