首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >仅选择具有一个子项的父项

仅选择具有一个子项的父项
EN

Stack Overflow用户
提问于 2013-07-23 08:14:35
回答 6查看 1K关注 0票数 1
代码语言:javascript
运行
复制
SELECT TOP 4000 Users.Id
  FROM Users
  JOIN Streams ON Users.Id = Streams.UserId
  JOIN Playlists ON Streams.Id = Playlists.StreamId
  WHERE Playlists.FirstItemId = '00000000-0000-0000-0000-000000000000'
  //  Doesn't work
  HAVING COUNT(1) = (
    SELECT COUNT(Playlists.Id)
    FROM Playlists WHERE Playlists.StreamId = Streams.Id
)

我正在尝试选择那些只有1个播放列表的流,并且其1个播放列表的FirstItemId为Guid.Empty的所有用户。我正在尝试做一些数据库维护和删除创建但从未使用过的帐户。

我已经让查询的第一部分工作得很好了,但是我不确定如何正确地应用我的“只有一个孩子”过滤器。

EN

回答 6

Stack Overflow用户

回答已采纳

发布于 2013-07-23 10:15:05

尝试下面的查询,以选择非活动用户输出

代码语言:javascript
运行
复制
SELECT TOP 4000 Users.Id
FROM Users
JOIN Streams ON Users.Id = Streams.UserId
JOIN Playlists ON Streams.Id = Playlists.StreamId
WHERE Playlists.FirstItemId = '00000000-0000-0000-0000-000000000000'
AND (SELECT COUNT(Playlists.Id) FROM Playlists WHERE Playlists.StreamId = Streams.Id) =1
票数 1
EN

Stack Overflow用户

发布于 2013-07-23 08:21:53

我认为使用WHERE NOT EXISTS子句可以很容易地实现这一点

代码语言:javascript
运行
复制
SELECT TOP 4000 Users.Id
  FROM Users
  JOIN Streams ON Users.Id = Streams.UserId
  JOIN Playlists ON Streams.Id = Playlists.StreamId
  WHERE Playlists.FirstItemId = '00000000-0000-0000-0000-000000000000'
  AND NOT EXISTS (
    SELECT 1 FROM Playlists
    WHERE Playlists.StreamId <> Playlists.FirstItemId
  )
)
票数 2
EN

Stack Overflow用户

发布于 2013-07-23 08:27:28

@seanmk有一个好主意...像这样..。

代码语言:javascript
运行
复制
SELECT TOP 4000 Users.Id
  FROM Users
  JOIN Streams ON Users.Id = Streams.UserId
  JOIN Playlists p ON Streams.Id = p.StreamId
  WHERE p.FirstItemId = '00000000-0000-0000-0000-000000000000'
  AND NOT EXISTS (
    SELECT 1 FROM Playlists q
    WHERE q.Id = p.Id
      AND q.FirstItemId <> p.FirstItemId
  )
)
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/17799501

复制
相关文章

相似问题

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