我将尝试在这里描述我的问题。假设我有 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。我将不胜感激。