1

在 MS Access 2010 中,我成功编写了一个查询,该查询从两个单独的表中为我提供了以下字段:[客户 ID]、[产品]、[价格]、[总价格] 和 [付款方式] 客户可以订购不同的产品或使用不同的付款方式。现在,我正在尝试有一个计算字段,该字段将仅给出每个客户在线支付的产品的总数/总和。

网上的[付款方式]代码是“D”。我将代码生成器表达式与以下表达式一起使用:

1) Sum(IIf([客户 ID] = [客户 ID] AND [付款方式] = "D", [价格], NULL))

但是,它一直给我这个错误消息:您尝试执行一个查询,该查询不包含指定表达式“客户 ID”作为聚合函数的一部分。

如果我想在 SQL(或表达式生成器)中执行此操作,我将如何执行?到目前为止,我尝试过的所有事情都会导致我收到相同的错误消息。

编辑
我的完整查询是:

SELECT CUSTOMER_INFO.ID AS [Customer ID], 
CUSTOMER_INFO.PROD_KEY AS [Product], 
CUSTOMER_INFO.PROD_PRICE AS [Price], 
CUSTOMER_INFO.SUM_PRICE AS [Total Price], 
PAYMENT_TRANZAK.PAY_METHD, 
Sum(IIf([Customer ID]=[Customer ID] And [PAY_MTHD]="D",[Price],[IsNull])) AS [Online Total]

FROM CUSTOMER_INFO INNER JOIN PAYMENT_TRANZAK ON (CUSTOMER_INFO.PROD_KEY= PAYMENT_TRANZAK.SSBSECT_CRN) AND (CUSTOMER_INFO.TERM_CODE_KEY = PAYMENT_TRANZAK.DATE_CODE)

WHERE (
((CUSTOMER_INFO.SUM_PRICE)>0) AND ((PAYMENT_TRANZAK.PAY_METHD) Is Not Null) AND     ((CUSTOMER_INFO.CUST_CODE)="RE" Or (CUSTOMER_INFO.CUST_CODE)="RW") AND   ((CUSTOMER_INFO.DATE_CODE)=[Please enter a transaction date: ]) AND   ((CUSTOMER_INFO.ESTS_CODE)="EL") AND ((CUSTOMER_INFO.STST_CODE)="AS")
)
ORDER BY CUSTOMER_INFO.ID;
4

2 回答 2

1

您正在尝试对非聚合数据执行聚合。为了求和,函数需要一些东西来求和;一组数据。因此,您将需要一个Group By子句。添加该子句GROUP BY CUSTOMER_INFO.ID将创建每个客户 ID 的总数。您也可以将付款类型子句添加到 where 语句中,以获得正确的付款类型逻辑。

SELECT CUSTOMER_INFO.ID AS [Customer ID]

  , Sum([Price]) AS [Online Total] 
FROM CUSTOMER_INFO 
INNER JOIN PAYMENT_TRANZAK 
ON (CUSTOMER_INFO.PROD_KEY= PAYMENT_TRANZAK.SSBSECT_CRN) 
    AND (CUSTOMER_INFO.TERM_CODE_KEY = PAYMENT_TRANZAK.DATE_CODE)
WHERE (((CUSTOMER_INFO.SUM_PRICE)>0) 
    AND ((PAYMENT_TRANZAK.PAY_METHD) Is Not Null) 
    AND ((CUSTOMER_INFO.CUST_CODE)="RE" Or (CUSTOMER_INFO.CUST_CODE)="RW") 
    AND ((CUSTOMER_INFO.DATE_CODE)=[Please enter a transaction date: ]) 
    AND ((CUSTOMER_INFO.ESTS_CODE)="EL") 
    AND ((CUSTOMER_INFO.STST_CODE)="AS"))
    AND PAYMENT_TRANZAK.PAY_METHD="D"
GROUP BY CUSTOMER_INFO.ID
ORDER BY CUSTOMER_INFO.ID; 

因为您没有聚合并非所有字段都被分组的所有字段,所以无法在这种查询中表达它们。这些

  • CUSTOMER_INFO.PROD_KEY AS [产品]
  • CUSTOMER_INFO.PROD_PRICE AS [价格]
  • CUSTOMER_INFO.SUM_PRICE AS [总价]
  • PAYMENT_TRANZAK.PAY_METHD

因此不是一个很好的匹配。

但是您比我更了解您的数据,也许有一种方法可以在逻辑上适应它们。这取决于你。

编辑:您可以尝试这样的查询,您不进行任何过滤,但您只需进行分组。这将显示所有内容,然后您对报告或表单进行过滤。

SELECT CUSTOMER_INFO.ID AS [Customer ID]
  , CUSTOMER_INFO.CUST_CODE
  , Sum(CUSTOMER_INFO.PROD_PRICE) AS [Online Total] 
  , Sum(CUSTOMER_INFO.SUM_PRICE) as [SumOfSumPrice]
  , CUSTOMER_INFO.CUST_CODE
  , PAYMENT_TRANZAK.PAY_METHD
  , CUSTOMER_INFO.DATE_CODE
  , CUSTOMER_INFO.ESTS_CODE
  , CUSTOMER_INFO.STST_CODE
FROM CUSTOMER_INFO 
INNER JOIN PAYMENT_TRANZAK 
ON (CUSTOMER_INFO.PROD_KEY= PAYMENT_TRANZAK.SSBSECT_CRN) 
    AND (CUSTOMER_INFO.TERM_CODE_KEY = PAYMENT_TRANZAK.DATE_CODE)
GROUP BY CUSTOMER_INFO.ID
  , CUSTOMER_INFO.CUST_CODE
  , PAYMENT_TRANZAK.PAY_METHD
  , CUSTOMER_INFO.DATE_CODE
  , CUSTOMER_INFO.ESTS_CODE
  , CUSTOMER_INFO.STST_CODE
ORDER BY CUSTOMER_INFO.ID;
于 2012-12-12T20:00:20.247 回答
0

在 MS SQL SERVER、ORACLE、MS ACCESS 中,您需要将 select 子句中的所有其他字段添加到聚合子句中。

从 Access Help 关于该主题的内容开始可能会有所帮助:

Jet SQL 帮助:SELECT 字段列表中的所有字段都必须包含在 GROUP BY 子句中或作为 SQL 聚合函数的参数包含在内。来自帮助系统的这句话暗示所有对字段的引用,即使在复合引用中,也必须可以聚合(即包含在上面列出的聚合函数之一中)或包含在 GROUP BY 子句中。任何一种类型的任何表达式都被认为是聚合的。聚合函数只能采用解析为非聚合字段的字段引用表达式(即,多次聚合数据同样无效)。

参考

由于聚合函数无论如何都会聚合您的查询,因此您可以在没有 group by 子句的情况下尝试它并查看。或者您可以包括每个字段。问题可能主要出在您的情况下,您有两个不同的字段,IIF但尚未处理空值。对于聚合,我会使用零或确保必须Isnull对 IIF 求和。

PS:我从手机发送了答案,第一次似乎没有完整的答案。

于 2012-12-12T18:20:03.310 回答