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的所有用户。我正在尝试做一些数据库维护和删除创建但从未使用过的帐户。
我已经让查询的第一部分工作得很好了,但是我不确定如何正确地应用我的“只有一个孩子”过滤器。
发布于 2013-07-23 10:15:05
尝试下面的查询,以选择非活动用户输出
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发布于 2013-07-23 08:21:53
我认为使用WHERE NOT EXISTS子句可以很容易地实现这一点
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
  )
)发布于 2013-07-23 08:27:28
@seanmk有一个好主意...像这样..。
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
  )
)https://stackoverflow.com/questions/17799501
复制相似问题