首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >每列的不同之处

每列的不同之处
EN

Stack Overflow用户
提问于 2009-06-03 10:34:35
回答 3查看 1.1K关注 0票数 1

我需要从一个表中选择3列,但我需要任何列中的每个值在该列的结果集中都是唯一的。

此查询:

代码语言:javascript
运行
复制
SELECT DISTINCT TOP 10 a, b, c
FROM   x

将返回10 distinct集。

我该怎么做呢?

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2009-06-03 10:49:19

代码语言:javascript
运行
复制
WITH q AS
        (
        SELECT  a, b, с, ROW_NUMBER() OVER (ORDER BY a, b, c) AS rn
        FROM    mytable
        )
SELECT  TOP 10 a, b, c
FROM    q q1
WHERE   NOT EXISTS
        (
        SELECT  1
        FROM    q
        WHERE   q.rn < q1.rn
                AND q.a = q1.a
        )
        AND NOT EXISTS
        (
        SELECT  1
        FROM    q
        WHERE   q.rn < q1.rn
                AND q.b = q1.b
        )
        AND NOT EXISTS
        (
        SELECT  1
        FROM    q
        WHERE   q.rn < q1.rn
                AND q.c = q1.c
        )
票数 4
EN

Stack Overflow用户

发布于 2009-06-03 10:39:38

this question没有给你想要的东西吗?

票数 1
EN

Stack Overflow用户

发布于 2009-06-03 10:41:22

我不知道这是否可能在一次拍摄中完成。我会通过创建一个表变量来做到这一点。

代码语言:javascript
运行
复制
DECLARE @Results TABLE
(
  a varchar(100),
  b varchar(100),
  c varchar(100)
)
INSERT @Results(a)
SELECT DISTINCT a FROM myTable

INSERT @Results(b)
SELECT DISTINCT b FROM myTable

INSERT @Results(c)
SELECT DISTINCT c FROM myTable

SELECT a,b,c FROM @Results
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/944061

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档