我需要写一个查询,以获得在每个国家销售的前10件商品。
数据库类型为MS Access 2013
表名: SoldItems字段国家项目
查询
此查询将得到每个国家销售的所有商品按每个国家销售的商品数量降序,我只需要在每个国家销售的前10件商品。
按国家、项目从SoldItems组中选择count(*)作为SoldItems、Country、Item
第2,1条命令c
发布于 2020-04-28 08:16:40
您将需要使用一个子查询,该查询返回按国家分组的前10项,并将其用作筛选器的基础。类似于:
SELECT S.Country, S.Item, COUNT(S.Item) AS CountOfItem
FROM SoldItems AS S
GROUP BY S.Country, S.Item
HAVING S.Item In (SELECT TOP 10 R.Item
FROM SoldItems AS R
GROUP BY R.Country, R.Item
HAVING R.Country=S.Country
ORDER BY COUNT(R.Item) DESC
)
ORDER BY S.Country, COUNT(S.Item) DESC;请注意,如果有相同数量的项目出售,那么您将得到超过10个记录返回每个国家。
致以敬意,
https://stackoverflow.com/questions/61466897
复制相似问题