繁体   English   中英

从t-SQL的两列中选择DISTINCT

[英]Select DISTINCT from two columns in t-SQL

说,如果我有下表:

CREATE TABLE tbl (ID INT, Type UNIQUEIDENTIFIER)
INSERT tbl VALUES
(1, N'D9D09D5B-AF63-484C-8229-9762B52972D0'),
(2, N'D9D09D5B-AF63-484C-8229-9762B52972D6'),
(3, N'D9D09D5B-AF63-484C-8229-9762B52972D9'),
(3, N'D9D09D5B-AF63-484C-8229-9762B52972D2'),
(4, N'D9D09D5B-AF63-484C-8229-9762B52972D0')

并且我需要选择不同的ID列,还需要选择与其关联的任何Type列值。 如果我执行以下操作:

select distinct id, type from tbl

当我只需要这个时,它将返回整个表:

1, N'D9D09D5B-AF63-484C-8229-9762B52972D0'
2, N'D9D09D5B-AF63-484C-8229-9762B52972D6'
3, N'D9D09D5B-AF63-484C-8229-9762B52972D9'
4, N'D9D09D5B-AF63-484C-8229-9762B52972D0'

我知道这一定很简单,但是我在这里想念的是什么?

根据您的评论,您需要选择列表中的第一种类型。 因此,您可以使用以下子查询来实现此目的:

SELECT id, (SELECT TOP 1 type FROM tbl a WHERE id = b.id)
FROM tbl b GROUP BY id

看到这个SQLFiddle

select id, min(type) from tbl group by id

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM