首页 > 解决方案 > 查询时使用 NOT IN 和 NOT EQUAL

问题描述

我有一个名为“Positions”的表格,我正在尝试从中获取特定信息。举个例子:

Position ID           Person

4                     Joe
5                     Mary
4                     Mary
6                     Shawn
4                     Brad
4                     Ken
8                     Ken

请注意,一个人可以有多个职位 ID。

我需要提取所有职位 ID 等于 4 的人员的姓名,但他们也不能有除 4 以外的其他职位 ID。

我已经尝试创建一个位置 ID 不是 4 的所有用户的列表,然后说我不希望该列表中的任何用户。逻辑是,这将删除 ID 不为 4 的人员,以及 ID 为 4 但职位 ID 不是 4 的用户。注意,这是在 MySQL 中,我对它比较陌生,但我会想象要遵循的 SQL 逻辑。

SELECT

Person

FROM

Positions

WHERE Person NOT IN

(
SELECT Person

FROM
Positions

WHERE
Position_ID <> 4
)

我希望结果只显示乔和布拉德

无论我做得多么简单,我的结果都没有得到任何回报。

标签: mysqlsqldatabasequerying

解决方案


首先,您正在对“Persons”进行 SELECT。您有两列名为 Position Id 和 Person。从那个开始

SELECT * FROM Positions WHERE person NOT IN (SELECT person WHERE position_id != 4);

推荐阅读