1

我将尝试在这里描述我的问题。假设我有 3 张桌子:

1.销售

  • 销售 ID (PK)
  • productID(FK) - 指向已售产品的 FK
  • storeID(FK) - 指向销售产品的商店的 FK
  • 月 - 产品销售的月份
  • year - 产品销售的年份
  • 金额 - 出售产品的金额(金额)

2.产品

  • 产品ID (PK)
  • 产品名称

3.商店

  • 商店 ID (PK)
  • 店名

我需要以下查询:对于每个商店,显示指定年份该商店中最畅销的产品。所以结果应该类似于:

STORE    PRODUCT    AMOUNT
store1   product1   XXX amount
store2   product2   YYY amount
store3   product1   XYX amount

其中每个金额将是该年度所有金额的最高总和。

我现在能做的是:

  SELECT store.storeName
       , product.ProductName
       , SUM(sales.ammount)
    FROM sales
    JOIN product ON sales.productID = product.productID
    JOIN store   ON sales.storeID   = store.storeID
GROUP BY store.storeName
       , product.ProductName
   WHERE sales.year = 'XXXX'
       ;

我从每个产品和每个商店得到一笔款项。在此之后,我可以使用光标逐行遍历整个表,并检查哪一个具有该商店的最高金额。

但我想知道是否可以在“简单”查询中做到这一点?

我正在为 Oracle 11g 数据库使用 SQL Developer。我将不胜感激。

4

1 回答 1

1

对 Oracle 不是很熟悉,但可能类似于:

WITH cte AS (SELECT store.storeName
                   , product.ProductName
                   , SUM(sales.ammount) as sales_amount
              FROM sales
              JOIN product ON sales.productID = product.productID
              JOIN store ON sales.storeID = store.storeID
              WHERE sales.year = 'XXXX'                  
              GROUP BY store.storeName, product.ProductName
              )
SELECT a.*
FROM cte a
JOIN (SELECT storeName
            , MAX(sales_amount) as Max_Sales
      FROM cte
      GROUP BY storeName
      )b
  ON a.storeName = b.StoreName
  AND a.sales_amount = b.Max_Sales;

如果存在一个返回两个条目的平局,则可以ROW_NUMBER()改为使用将每个 storeName 限制为一个结果。

于 2013-09-13T22:51:04.617 回答