取一种类型里面的产品销售前3甲的数据Sql

需求:取出每种分类里面的销售前3甲的产品信息

表设计如下图:

数据如下:

两种方法可以实现:

1.

SELECT * FROM
(
SELECT ROW_NUMBER() OVER(PARTITION BY categoryID ORDER BY saleNum desc) AS SaleSeq,* FROM productSale
) a
WHERE SaleSeq < 4

2.
SELECT * FROM dbo.ProductSale t
WHERE ProductID IN
(
 SELECT TOP 3 ProductID FROM dbo.ProductSale m
 WHERE m.CategoryID = t.CategoryID
 ORDER BY SaleNum DESC
)
ORDER BY t.CategoryID, t.SaleNum DESC

结果如下图:

说明:此2种方法可以在前3甲的产品销售数量不相等时准确查询出前3甲的产品销售信息,但如果前3甲中有销售数量相同的产品,

则有可能是少取了另一些产品,比如销售第一1种产品,销售第二1种产品,销售第三3种产品,

则会在销售第三的3种产品中取一个产品返回,其实是少了并列的2种产品的,此处需要注意。

原文地址:https://www.cnblogs.com/itjeff/p/4326140.html