首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >查询返回多个相同的行,而不是返回一个

查询返回多个相同的行,而不是返回一个
EN

Stack Overflow用户
提问于 2016-05-28 05:05:33
回答 2查看 59关注 0票数 0

我有几张桌子:juicesjuice_ingredientsingredients

juices表具有以下属性:

  • 名字
  • 条形码

juice_ingredients表具有以下属性:

  • juice_id
  • ingredient_id

ingredients表有

  • 名字
  • 可选(布尔值)

为了客户的物流,各种果汁可能有相同的条形码,但有不同的成分,其中一些是可选的,我需要选择,通过条形码,单一的果汁,没有可选的成分,其中的成分。

我注册了四种成分:水(可选:假)、糖(可选:真)、菠萝果肉(可选:假)和薄荷(可选:真)。并签署了四份果汁:一份只加水和菠萝浆,另一份加水,菠萝浆和糖,另一份加水,菠萝浆和薄荷,还有水,菠萝浆,薄荷和糖。都有相同的条形码。我做了一个查询,只选择果汁的非可选成分,在这种情况下,水和菠萝果肉。

代码语言:javascript
复制
SELECT *
FROM juices
INNER JOIN juice_ingredients ON (juice_ingredients.juice_id = juices.id)
INNER JOIN ingredients ON (juice_ingredients.ingredient_id = ingredients.id)
WHERE juices.barcode = '000000000001' AND ingredients.optional = false

但它会返回多行。什么应该改变这个查询,以只带来一个,或果汁中没有可选的成分组成?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2016-05-28 05:17:49

由于您没有指定正在使用的数据库,因此可能必须针对特定数据库调整SQL:

代码语言:javascript
复制
select *
  from juices j
 where j.barcode = '000000000001'
   and not exists (select *
                     from juice_ingredients ji
                    inner join ingredients i
                       on (i.ingredient_id = ji.ingredient_id
                      and i.optional = true)
                    where ji.juice_id = j.juice_id)
票数 1
EN

Stack Overflow用户

发布于 2016-05-28 05:27:23

您可以使用一个having子句来完成这个任务:

代码语言:javascript
复制
SELECT juices.*
FROM juices
JOIN juice_ingredients ON juice_ingredients.juice_id = juices.id
JOIN ingredients ON juice_ingredients.ingredient_id = ingredients.id
WHERE juices.barcode = '000000000001'
GROUP BY 1, 2
HAVING MAX(ingredients.optional::text) = 'false'
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/37495390

复制
相关文章

相似问题

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