访问查询和 VBA SQL 为"Having"返回不同的数据



我在查询编辑器中使用以下SQL进行查询:

SELECT tbl_PN_Import.PN, Last(tbl_PN_Import.Master_PN) AS Master_PN
FROM tbl_PN_Import
GROUP BY tbl_PN_Import.PN
Having (((Last(tbl_PN_Import.Master_PN)) Is Not Null))
ORDER BY tbl_PN_Import.PN;`

它在查询编辑器中返回 10,000+ 条记录。

下面是示例记录的列表。我们的数据库包含主零件号,这些主零件号与备用零件号具有一对多关系。 PN 字段包含所有部件号,包括主部件号和备用部件号。 如果 PN 是主 PN,则在Master_PN字段中没有条目。 如果 PN 是备用部件号,则其Master_PN位于Master_PN字段中。

PN                 Master_PN 
NAS1149FN432P 
AN960-4            NAS1149FN432P 
AD64ALS 
SSPQ-4-3 
SSPQ-04-03         SSPQ-4-3

当我使用 SQL 字符串变量在 VBA 中运行查询并.OpenRecordSet它只返回第一条记录时。 当我删除Having....时,它会返回预期的 70,000+ 条记录。

我还有其他查询,没有可以正常工作的Having...动词。

任何帮助,不胜感激。

尝试只过滤掉值:

SELECT tbl_PN_Import.PN, Last(tbl_PN_Import.Master_PN) AS Master_PN
FROM tbl_PN_Import
WHERE tbl_PN_Import.Master_PN Is Not Null
GROUP BY tbl_PN_Import.PN
ORDER BY tbl_PN_Import.PN

或者,因为Last只返回"一个值":

SELECT tbl_PN_Import.PN, Max(tbl_PN_Import.Master_PN) AS Master_PN
FROM tbl_PN_Import
WHERE tbl_PN_Import.Master_PN Is Not Null
GROUP BY tbl_PN_Import.PN
ORDER BY tbl_PN_Import.PN

LAST不是在未排序的结果集上定义的,这意味着任何行都可以。使用子查询强制实施特定顺序,或完全避免使用LAST

子查询的一个示例是:

SELECT PN, Last(Master_PN) AS Master_PN
FROM (SELECT * FROM tbl_PN_Import ORDER BY Some_ID_field)
GROUP BY PN
Having Last(Master_PN) Is Not Null
ORDER BY tbl_PN_Import.PN;

如果您没有 ID 字段或任何可以订购的内容,则不能指望LAST产生一致的结果。

最新更新