首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >Access查询和VBA SQL返回"Having“的不同数据

Access查询和VBA SQL返回"Having“的不同数据
EN

Stack Overflow用户
提问于 2020-06-21 09:34:27
回答 2查看 41关注 0票数 0

我在查询编辑器中有一个包含以下SQL的查询:

代码语言:javascript
复制
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字段中。

代码语言:javascript
复制
PN                 Master_PN 
NAS1149FN432P 
AN960-4            NAS1149FN432P 
AD64ALS 
SSPQ-4-3 
SSPQ-04-03         SSPQ-4-3

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

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

任何帮助都是非常感谢的。

EN

回答 2

Stack Overflow用户

发布于 2020-06-21 17:53:42

尝试过滤掉Null值:

代码语言:javascript
复制
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只返回"a value":

代码语言:javascript
复制
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
票数 1
EN

Stack Overflow用户

发布于 2020-06-21 20:17:38

没有在未排序的结果集上定义LAST,这意味着任何行都可以。使用子查询来强制执行特定的订单,或者完全避免使用LAST

子查询的一个例子是:

代码语言:javascript
复制
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产生一致的结果。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/62493539

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档