首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
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

Stack Overflow用户

发布于 2013-07-23 08:29:46

下面的查询应该能满足您的要求。

代码语言: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 Playlists.StreamId IN (
  SELECT Playlists.StreamId
  FROM Playlists
  GROUP BY Playlists.StreamId
  HAVING COUNT(*) = 1
)
票数 1
EN
查看全部 6 条回答
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/17799501

复制
相关文章

相似问题

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