0

这是获得一些奖牌的简单问题:):我有三个表:“联系人”,其中包含联系人信息,其中每个条目都有一个唯一的 ID。第二个表“groups”存储每个组的名称和组 ID。最后一个“contacts_groups”将每个联系人绑定到一个组,它只有两列,contact_id 和 group_id。

问题是如何在单个语句中编写一个 MySQL 查询,该查询将选择未分配给组的所有联系人。换句话说,“contacts_groups”表中未列出 id 的联系人?

4

3 回答 3

2
select * from contacts c
left outer join contacts_groups cg on c.id = cg.contact_id 
where cg.contact_id is null
于 2012-10-29T23:28:50.310 回答
1
SELECT * FROM contacts c
WHERE NOT EXISTS (SELECT * FROM contacts_groups cg
                  WHERE cg.contact_id = c.contact_id)
于 2012-10-29T23:30:15.377 回答
1

为了完整起见,这是另一个解决方案:

SELECT * FROM contacts
WHERE contact_id NOT IN (SELECT contact_id FROM contacts_groups)

但是,我认为 MySQL 倾向于更有效地执行左连接或关联子查询。

于 2012-10-29T23:38:30.620 回答