首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在MS Access中填充数据表的查询,如果未返回值,则为MsgBox

在MS Access中填充数据表的查询,如果未返回值,则为MsgBox
EN

Stack Overflow用户
提问于 2016-09-15 04:58:05
回答 1查看 39关注 0票数 0

我正在尝试创建一个可以从MS Access中的按钮运行的查询。我创建的SQL查询如下:

代码语言:javascript
复制
PARAMETERS CASNUMBER Text ( 255 ); 
SELECT DISTINCT Chemical.Chemical_Name, Hazard.Hazard_Code, Hazard.Hazard_Text 
FROM Chemical, Chemical_Hazard, Hazard 
WHERE Chemical.Chemical_Id = Chemical_Hazard.Chemical_Id 
and Chemical_Hazard.Hazard_Id = Hazard.Hazard_Id 
and [CASNUMBER] = Chemical.CAS

如何才能在没有返回值的情况下显示MsgBox?

EN

回答 1

Stack Overflow用户

发布于 2016-09-15 12:41:46

我建议使用JOIN而不是WHERE来连接表。此外,您还可以避免使用参数,因为在大多数情况下,它会重复使用VBA代码来执行查询。不带参数的create query,将CAS添加到列列表:

代码语言:javascript
复制
SELECT DISTINCT Chemical.Chemical_Name
    ,Hazard.Hazard_Code
    ,Hazard.Hazard_Text
    ,Chemical.CAS
FROM (
    Chemical_Hazard INNER JOIN Chemical ON Chemical.Chemical_Id = Chemical_Hazard.Chemical_Id
    )
INNER JOIN Hazard ON Chemical_Hazard.Hazard_Id = Hazard.Hazard_Id

然后在代码中检查CAS:

代码语言:javascript
复制
If DCount("*", "MyQuery", "CAS=" & lngCASNumber) = 0 then
    MsgBox "CAS not found"
End If
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/39499539

复制
相关文章

相似问题

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