首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用sql查询拉取常用ID

使用sql查询拉取常用ID
EN

Stack Overflow用户
提问于 2020-03-04 05:21:24
回答 3查看 37关注 0票数 0

表名: Account

列:

代码语言:javascript
复制
ParentID      RecordType
ABC100        X
ABC100        Y
EFG100        x
HIJ200        x
JKL200        Y
UVW100        Y
UVW100        X

如何拉取ParentID ABC100和UVW100?我只想拉出那些记录类型既有X又有Y的父代?

EN

回答 3

Stack Overflow用户

发布于 2020-03-04 05:22:54

您可以使用聚合。如果您没有副本:

代码语言:javascript
复制
select parentid
from t
where recordtype in ('X', 'Y')
group by parentid
having count(*) = 2;

或者,如果表中有重复项:

代码语言:javascript
复制
having min(recordtype) <> max(recordtype)
票数 0
EN

Stack Overflow用户

发布于 2020-03-04 05:25:05

如果表的大小不是很大,并且内部查询的大小不超过2100,则可以使用内部查询。

代码语言:javascript
复制
SELECT parentId 
FROM Account 
WHERE recordType = 'X' 
AND parentId IN 
(SELECT parentId FROM Account WHERE recordType = 'Y')
票数 0
EN

Stack Overflow用户

发布于 2020-03-04 05:31:43

为了使您的选择更加完善,您还可以组合使用WHEREWHERE EXISTS

代码语言:javascript
复制
select
 ParentID
from 
  account as o
where
  RecordType = 'X'
  and
  exists (select 1
          from account as i 
          where 
            i.ParentID = o.ParentID
            and
            i.RecordType = 'Y'
          );
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/60515705

复制
相关文章

相似问题

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