这是获得一些奖牌的简单问题:):我有三个表:“联系人”,其中包含联系人信息,其中每个条目都有一个唯一的 ID。第二个表“groups”存储每个组的名称和组 ID。最后一个“contacts_groups”将每个联系人绑定到一个组,它只有两列,contact_id 和 group_id。
问题是如何在单个语句中编写一个 MySQL 查询,该查询将选择未分配给组的所有联系人。换句话说,“contacts_groups”表中未列出 id 的联系人?
这是获得一些奖牌的简单问题:):我有三个表:“联系人”,其中包含联系人信息,其中每个条目都有一个唯一的 ID。第二个表“groups”存储每个组的名称和组 ID。最后一个“contacts_groups”将每个联系人绑定到一个组,它只有两列,contact_id 和 group_id。
问题是如何在单个语句中编写一个 MySQL 查询,该查询将选择未分配给组的所有联系人。换句话说,“contacts_groups”表中未列出 id 的联系人?
select * from contacts c
left outer join contacts_groups cg on c.id = cg.contact_id
where cg.contact_id is null
SELECT * FROM contacts c
WHERE NOT EXISTS (SELECT * FROM contacts_groups cg
WHERE cg.contact_id = c.contact_id)
为了完整起见,这是另一个解决方案:
SELECT * FROM contacts
WHERE contact_id NOT IN (SELECT contact_id FROM contacts_groups)
但是,我认为 MySQL 倾向于更有效地执行左连接或关联子查询。