这是获得一些奖牌的简单问题:): 我有三张桌子: “联系人”,其中包含每个条目具有唯一ID的联系人信息。 第二个表“groups”,其中存储每个组的名称和组ID。 最后一个“contacts_groups”将每个联系人绑定到一个组,它只有两列,contact_id和group_id。
问题是如何在单个语句中写入一个MySQL查询,该查询将选择未分配给组的所有联系人。换句话说,哪些ID未在“contacts_groups”表中列出?
答案 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倾向于更有效地执行左连接或相关子查询。