0

我正在尝试使用 Oracle SQL 查询进行验证,其想法是:

有项目,每个项目可能有多个供应商。

我有一组物品(在购物袋中),想验证它们之间是否至少有一个共同的供应商。这意味着袋子中的所有物品至少共享一个供应商。

简而言之,这些表是:

带有 bag_id 和 item 列的 BAG 表。
带有项目和供应商列的供应表。

谢谢!

4

2 回答 2

1

这应该为您提供与多个项目匹配的供应商列表,最常见的供应商位于顶部

SELECT SUPPLY.supplier, COUNT(SUPPLY.item) item_count
FROM BAG
JOIN SUPPLY
  ON BAG.item = SUPPLY.item
GROUP BY SUPPLY.supplier
HAVING COUNT(SUPPLY.item) > 1
WHERE BAG.bag_id = ? --substitute bag_id
ORDER BY COUNT(SUPPLY.item) DESC

如果您需要查找与包中所有商品匹配的供应商,请使用以下查询:

SELECT SUPPLY.supplier
FROM BAG
JOIN (SELECT bag_id, COUNT(*) as item_count FROM BAG GROUP BY bag_id WHERE bag_id = ?) bag_count
  ON BAG.id = bag_count.bag_id
JOIN SUPPLY
  ON BAG.item = SUPPLY.item
GROUP BY SUPPLY.supplier
HAVING COUNT(SUPPLY.item) = bag_count.item_count
WHERE BAG.bag_id = ?

您可以检查列表是否为空,以确定是否不存在通用供应商,方法是用EXISTS语句包装它。

于 2012-08-23T18:06:30.413 回答
0
select case when exists
                       (
                        select 1
                        from bag b
                             inner join item i on i.id = b.item_id
                             inner join supplier s on s.id = i.supplier_id
                                                   and s.is_main = 'Y'
                       )
             then 'Y'
             else 'N'   
       end contains_main_supplier                   
from dual
于 2012-08-23T18:16:12.047 回答