查询两个表,其结果与join like语句相反

时间:2012-10-29 23:24:17

标签: mysql

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

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

3 个答案:

答案 0 :(得分:2)

select * from contacts c
left outer join contacts_groups cg on c.id = cg.contact_id 
where cg.contact_id is null

答案 1 :(得分:1)

SELECT * FROM contacts c
WHERE NOT EXISTS (SELECT * FROM contacts_groups cg
                  WHERE cg.contact_id = c.contact_id)

答案 2 :(得分:1)

要完成,这是另一种解决方案:

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

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