需求:取出每种分类里面的销售前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种产品的,此处需要注意。