首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >选择多次出现的行。

选择多次出现的行。
EN

Stack Overflow用户
提问于 2014-03-19 15:03:21
回答 3查看 4.4K关注 0票数 5
代码语言:javascript
运行
复制
   TableOne

      PersonId        PersonScore
         1                10
         1                20
         2                99
         2                40
         3                45

我只需要获取那些PersonId出现不止一次的行,例如,下面是我想实现的结果集

代码语言:javascript
运行
复制
     PersonId        PersonScore
         1                10
         1                20
         2                99
         2                40

我在用cte

代码语言:javascript
运行
复制
  ;WITH cte AS (
   SELECT  *, ROW_NUMBER() OVER (PARTITION BY i.PersonId ORDER BY i.PersonId) AS [Num]
   FROM    TableOne i
   )
   SELECT  *
   FROM    cte
   WHERE   cte.Num > 1

问题是它删除了额外的行。它移动任何PersonId的第一个实例。有谁能提出解决办法吗?

EN

Stack Overflow用户

发布于 2014-03-19 15:13:03

您可以使用一个简单的相关子查询:

代码语言:javascript
运行
复制
SELECT PersonId, PersonScore
FROM dbo.TableOne t1
WHERE (SELECT COUNT(*) 
       FROM dbo.TableOne t2 
       WHERE t1.PersonId = t2.PersonID) > 1
票数 2
EN
查看全部 3 条回答
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/22509939

复制
相关文章

相似问题

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