如何在sql中找到客户明智类别中的最大产品ID?

Posted

技术标签:

【中文标题】如何在sql中找到客户明智类别中的最大产品ID?【英文标题】:How to find the maximum product id in customer wise category in sql? 【发布时间】:2021-05-15 21:40:48 【问题描述】:

这里我有客户 ID 和最大订单数量,我如何获取最大订单数量的 productid 列以及 customerid 和 maxorderqty 列。

数据库:冒险作品 使用的表:salesorerheader、salesorderdetails

SELECT customerid,
       Max(totalqty)
FROM   (SELECT customerid,
               Sum(orderqty) AS Totalqty,
               productid     AS pdtid
        FROM   sales.salesorderheader a
               INNER JOIN sales.salesorderdetail b
                       ON a.salesorderid = b.salesorderid
        GROUP  BY customerid,
                  productid)A
WHERE  customerid = 29825
GROUP  BY customerid

【问题讨论】:

嗨!由于您是新人,我想邀请您提供有关数据库的更多详细信息。如果您可以更完整地概述您的表格的外观,这将对贡献者有所帮助。提供一个最小的工作示例总是有帮助的,所以在这里举一个例子,当你用一些数据填充表格时,你的表格看起来如何是个好主意。由于您已经提供了一个您尝试过的查询,如果您添加查询当前产生的输出以及您期望它产生的输出将会很有帮助。 【参考方案1】:

如果您对查找单个记录感兴趣,可以使用以下内容:

SELECT TOP(1) CustomerID, max(totalqty) AS maxqty, pdtid
FROM
(
  SELECT customerid, Sum(orderqty) AS Totalqty, productid AS pdtid
  FROM   sales.salesorderheader a
    INNER JOIN sales.salesorderdetail b
      ON a.salesorderid = b.salesorderid
  GROUP  BY customerid, productid
) A
WHERE CustomerID=29825
GROUP BY CustomerID, pdtid
ORDER BY max(totalqty) DESC

但是...如果你想找到多个具有相同排名的记录,请使用:

SELECT *
FROM 
(
  SELECT RANK() OVER(ORDER BY max(totalqty) DESC) rnk, CustomerID, max(totalqty) AS maxqty, pdtid
  FROM
  (
    SELECT customerid, Sum(orderqty) AS Totalqty, productid AS pdtid
    FROM   sales.salesorderheader a
      INNER JOIN sales.salesorderdetail b
        ON a.salesorderid = b.salesorderid
    GROUP  BY customerid, productid
  ) A
  WHERE CustomerID=29825
  GROUP BY CustomerID, pdtid
) B
WHERE rnk = 1

db<>fiddle

另一种方法是再次“加入”航行详情;)

【讨论】:

嘿,谢谢伙计,但我想要的是 maxorder 的相应产品 id,我已经为客户计算了 maxqty 但我想包括产品 id,如果我选择产品我需要使用 group by这会带来不同的结果,我能做些什么吗? 对不起,你试过上面的查询吗?看来,你没有。看看这里:db<>fiddle。结果和你的完全一样,包含productid

以上是关于如何在sql中找到客户明智类别中的最大产品ID?的主要内容,如果未能解决你的问题,请参考以下文章

CakePHP 我将如何获取类别明智的产品?

分类明智的产品销售 laravel

如何在 WooCommerce 中使用 SQL 查询选择特定类别的产品

sql 查询以检索Magento中的所有产品ID及其所属的类别。

如何从 WooCommerce 中的订单项中获取产品类别 ID

如何从functions.php中的简码挂钩中排除产品类别ID - WooCommerce