首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何查询包含给定多个关系的所有值的所有行?(不仅仅是其中一个!)

如何查询包含给定多个关系的所有值的所有行?(不仅仅是其中一个!)
EN

Stack Overflow用户
提问于 2015-01-08 11:49:51
回答 1查看 73关注 0票数 0

我遵循数据库结构:

  • 表1:家具(字段: ID)
  • 表2:材料(字段: ID)
  • 表3: MaterialMatching:(字段: ID、FK_Furniture、FK_Material)

这种结构可以将许多材料与每件家具联系起来.

我知道如何查询所有家具,这些家具有一些特殊的材料,其中材料之间的逻辑关系是OR:

代码语言:javascript
复制
select distinct(furniture.ID) from Furniture 
    left join MaterialMatching ON MaterialMatching.FK_Furniture = Furniture.ID
    left join Material On Material.ID = MaterialMatching.FK_Material
    where Material.ID IN (<< material ids I want to query>>)

问题

我怎样才能查询所有有所有材料的家具?我想要所有的家具,有材料1和材料2和.

EN

回答 1

Stack Overflow用户

发布于 2015-01-08 15:43:39

这是一个相当肮脏的独处,但它应该解决它。它将归还所有分配给它的家具。

代码语言:javascript
复制
select f.* 
from Furniture f
left join (select ftemp.id, count(distinct(mm.FK_Material)) matcount 
           from Furniture ftemp
           left join MaterialMatching mm on mm.FK_Furniture = ftemp.ID
           group by ftemp.id) mmtemp on f.id = mmtemp.id
where mmtemp.matcount = (select count(1) from Material)
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/27839458

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档