1

我正在尝试为 MS Access 构建一个 SQL 语句,以按产品从我们的数据库中获取所有销售,这些销售在 2013 年 1 月 1 日之前从未出售给特定客户。我相信以下 SQL 语句可以做到这一点:

SELECT
  Sales.CustomerID,
  Min(Sales.InvoiceDate) AS MinOfInvoiceDate,
  Sum(SalesDetail.StdCost) AS SumOfStdCost
FROM
  Sales INNER JOIN SalesDetail
  ON Sales.SalesID = SalesDetail.SalesID
GROUP BY
  Sales.CustomerID
HAVING
  (((Min(Sales.InvoiceDate))>=#1/1/2013#));

销售表包含:ID、发票编号、客户 ID 和日期。(我称之为发票,但我没有设计它......)SalesDetail 是每个发票行项目:销售/发票ID、产品ID/编号、数量和成本

我的问题是,我将如何按月进一步细分?任何帮助表示赞赏!

编辑:好的!:) 所以这是上述查询的输出示例:

CustomerID | MinOfInvoice | SumOfStdCost
Customer1  | 2/1/2013     | $300

我想要的是显示每张发票及其日期(或只是月份,没关系),同时保持最小发票日期大于 2013 年 1 月 1 日的客户的分组/表达式(?)标准,比如所以

CustomerID | InvoiceDateMonth  | StdCost
Customer1  | 2/1/2013          | $100
Customer1  | 3/15/2013         | $130
Customer1  | 4/7/2013          | $70

Customer1 在 2013 年 1 月 1 日之后开始收到发票,因此应该列出它们。

Customer2 有 2012 年和 2013 年的发票,所以应该不在查询结果中。

我真的希望这是可能的,我已经为此努力了好几天,并且宁愿跳过必须在我的代码中单独检查每个客户的痛苦过程。:(我相信让数据库完成这项工作。;)

再次感谢任何帮助!

4

1 回答 1

0

您可以通过执行非常相似的查询来为这些客户提取更多详细信息,该查询使用原始查询的“精简”版本作为子查询,以将结果限制为感兴趣的客户。所有客户的基本查询将是......

SELECT
    Sales.CustomerID,
    Sales.InvoiceDate,
    SalesDetail.StdCost
FROM
    Sales INNER JOIN SalesDetail
        ON Sales.SalesID = SalesDetail.SalesID

...因此我们可以简单地添加一个 WHERE 子句,该子句使用类似于您的原始查询的逻辑来仅包含我们想要的客户

SELECT
    Sales.CustomerID,
    Sales.InvoiceDate,
    SalesDetail.StdCost
FROM
    Sales INNER JOIN SalesDetail
        ON Sales.SalesID = SalesDetail.SalesID
WHERE 
    Sales.CustomerID IN
        (
            SELECT CustomerID 
            FROM Sales
            GROUP BY CustomerID
            HAVING MIN(InvoiceDate)>=#2013-01-01#
        )

另一种方法是使用稍微不同的子查询来排除具有较早发票的客户

SELECT
    Sales.CustomerID,
    Sales.InvoiceDate,
    SalesDetail.StdCost
FROM
    Sales INNER JOIN SalesDetail
        ON Sales.SalesID = SalesDetail.SalesID
WHERE 
    Sales.CustomerID NOT IN
        (
            SELECT CustomerID 
            FROM Sales
            WHERE InvoiceDate<#2013-01-01#
        )
于 2013-05-14T07:49:24.573 回答