sql server distinct 过滤两个字段重复怎么写?
1、SELECTdistinct字段名,IDFROM表名2、SELECTdistinct字段名FROM表名第一种两个字段过滤重复的就不好使,第二种过滤一个重复的就好使第一...
1、SELECT distinct 字段名 ,ID FROM 表名
2、SELECT distinct 字段名 FROM 表名
第一种两个字段过滤重复的就不好使,第二种过滤一个重复的就好使
第一种怎么改一下才能是正确的呢? 展开
2、SELECT distinct 字段名 FROM 表名
第一种两个字段过滤重复的就不好使,第二种过滤一个重复的就好使
第一种怎么改一下才能是正确的呢? 展开
2个回答
展开全部
后面跟多个字段的话,就是要多个字段同时重复才能过滤
其实道理很简单,举个例子,如果数据是
id name
1 aaa
2 aaa
select distinct id,name from tab
这个语句的返回结果必然是两条,因为如果是1条的话,id 有两个值,就没法显示,随机取数这种事情如果没有指令,数据库自己是没有这个功能的。
解决方法:
比如name相同的记录,我要id最小的
select * from tab a where not exists (select 1 from tab where name = a.name and id < a.id)
搞定!
其实道理很简单,举个例子,如果数据是
id name
1 aaa
2 aaa
select distinct id,name from tab
这个语句的返回结果必然是两条,因为如果是1条的话,id 有两个值,就没法显示,随机取数这种事情如果没有指令,数据库自己是没有这个功能的。
解决方法:
比如name相同的记录,我要id最小的
select * from tab a where not exists (select 1 from tab where name = a.name and id < a.id)
搞定!
追问
exists是什么意思?
追答
一种查询方式
exists 是存在的意思,not exists是不存在
exists意思是判断后面()里的子查询是否存在记录,如果有多条,那不管有多少条,只要找到第一条,就返回真
not exists同理
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询