zoukankan      html  css  js  c++  java
  • 取一种类型里面的产品销售前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种产品的,此处需要注意。

  • 相关阅读:
    053-649
    053-648
    053-647
    053-646
    053-645
    053-644
    053-643
    053-642
    053-641
    053-640
  • 原文地址:https://www.cnblogs.com/itjeff/p/4326140.html
Copyright © 2011-2022 走看看