首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用MS Access Union查询合并3个表/查询

使用MS Access Union查询合并3个表/查询
EN

Stack Overflow用户
提问于 2011-01-07 19:53:30
回答 2查看 23.9K关注 0票数 3

我已经建立了一个MySQL数据库来存储账单支付。我办公室里的每个人都有MS,所以我正在构建一个前端数据库报告工具,使用MS并链接到后端的MySQL表。

我已经创建了一些访问查询,这些查询引用了MySQL表,进行了一些操作,现在我希望将三个查询(具有相同的表结构)合并回一个可以构建我的报告的查询。

通过我的研究(article1article2和其他),我发现Union查询是我所需要的。我可以合并2个表,但是当我尝试合并第三个表时,查询无法执行。我已经单独测试了每个组合的Union查询(1-2,1-3,2-3),任何一对都有效。我试图理解我可能做错了什么,以便将第三个查询合并到一个联合中。你能提出什么建议吗?

表1=表2=B表3=C

代码语言:javascript
复制
SELECT A.Year, A.BillingQuarter, A.Name, A.ObjectCode, A.Amount
FROM A

UNION  ALL SELECT B.Year, B.BillingQuarter, B.Name, B.ObjectCode, B.Amount
FROM B

UNION ALL SELECT C.Year, C.BillingQuarter, C.Name, C.ObjectCode, C.Amount
FROM C

* UPDATE *在将每个查询导出到独立表之后,我能够运行一个3表UNION ALL查询并将它们合并在一起。因此,问题显然在于我试图联合3次查询,而不是在3个表中。有什么想法?

谢谢!

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2011-01-07 21:31:43

我无法在Access中测试这一点,但它在Server中工作,请选择前两个带有UNION表的表作为派生表,然后选择UNION表C和派生表。

代码语言:javascript
复制
SELECT Year, BillingQuarter, Name, ObjectCode, Amount FROM
    (SELECT Year, BillingQuarter, Name, ObjectCode, Amount FROM @A
    UNION ALL
    SELECT Year, BillingQuarter, Name, ObjectCode, Amount FROM B)
    AS Derived
    UNION ALL
    SELECT Year, BillingQuarter, Name, ObjectCode, Amount FROM C

可能值得研究一下模式设计/关系,看看是否可以避免这种情况。

票数 2
EN

Stack Overflow用户

发布于 2018-01-27 02:07:11

您需要一个分号(;)来结束查询。见下文:

代码语言:javascript
复制
SELECT Year, BillingQuarter, Name, ObjectCode, Amount FROM
    (SELECT Year, BillingQuarter, Name, ObjectCode, Amount FROM @A
    UNION ALL
    SELECT Year, BillingQuarter, Name, ObjectCode, Amount FROM B)
    AS Derived
    UNION ALL
    SELECT Year, BillingQuarter, Name, ObjectCode, Amount FROM C;
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/4629659

复制
相关文章

相似问题

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