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

时间:2011-01-07 19:53:31

标签: mysql ms-access union-all

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

我创建了一些引用MySQL表的Access查询,完成了一些操作,现在想要将三个查询(具有相同的表结构)合并回一个我可以构建报表的查询。

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

表1 = A. 表2 = B. 表3 = C

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

*更新* 将每个查询导出到独立表后,我能够运行3表UNION ALL查询并将它们合并在一起。所以问题显然在于我尝试UNION 3查询,而不是3个表。想法?

谢谢!

2 个答案:

答案 0 :(得分:0)

我无法在Access中测试它,但它可以在SQL Server中运行,选择前两个表,其中UNION作为派生表,然后是UNION表C和派生表。

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

可能值得查看架构设计/关系,看看是否可以避免这种情况。

答案 1 :(得分:0)

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

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;