Select 只有(至少)是某些组成员的用户
Select only users that are (at least) member in certain groups
我一直在进行查询以获取用户列表及其各自的组。
我知道了。
但是有一些限制:
- 如果用户只是 group5 的成员,则不应出现在列表中
- 如果是 group5 和其他组的成员,它应该出现在列表中
我可以获得不是 group5 成员的用户,如果他们是成员,他们不会出现在列表中。
我的问题是 group5 的用户成员和其他组的成员,他们没有出现,但他们应该出现在列表中
这里是查询:
select
user_id, group_id
from
group_users
where
group_id != 5
and user_id not in (select distinct user_id
from group_users
where group_id = 5)
例如应该出现用户 1 和 2,他们是 group1、group2 和 group5 的成员。这些用户不会出现,因为 group5,即使他们有其他组,他们也应该出现。
另一方面,user3只是group5的成员,因此,该用户不会出现。
换句话说,您只需要至少有一个 group_id
的用户,即 <> 5
:
SELECT user_id, group_id
FROM group_users gu
WHERE group_id <> 5 -- optional, might help performance
OR EXISTS ( -- just this works, too
SELECT 1 FROM group_users
WHERE user_id = gu.user_id
AND group_id <> 5
)
如果添加更多 WHERE
子句,请将这两个表达式括在括号中。运算符优先级。
我一直在进行查询以获取用户列表及其各自的组。
我知道了。
但是有一些限制:
- 如果用户只是 group5 的成员,则不应出现在列表中
- 如果是 group5 和其他组的成员,它应该出现在列表中
我可以获得不是 group5 成员的用户,如果他们是成员,他们不会出现在列表中。
我的问题是 group5 的用户成员和其他组的成员,他们没有出现,但他们应该出现在列表中
这里是查询:
select
user_id, group_id
from
group_users
where
group_id != 5
and user_id not in (select distinct user_id
from group_users
where group_id = 5)
例如应该出现用户 1 和 2,他们是 group1、group2 和 group5 的成员。这些用户不会出现,因为 group5,即使他们有其他组,他们也应该出现。
另一方面,user3只是group5的成员,因此,该用户不会出现。
换句话说,您只需要至少有一个 group_id
的用户,即 <> 5
:
SELECT user_id, group_id
FROM group_users gu
WHERE group_id <> 5 -- optional, might help performance
OR EXISTS ( -- just this works, too
SELECT 1 FROM group_users
WHERE user_id = gu.user_id
AND group_id <> 5
)
如果添加更多 WHERE
子句,请将这两个表达式括在括号中。运算符优先级。