【问题标题】:Merging 3 tables/queries using MS Access Union Query使用 MS Access Union Query 合并 3 个表/查询
【发布时间】:2011-01-07 19:53:30
【问题描述】:

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

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

通过我的研究(article1article2 等),我发现我需要一个联合查询。我可以很好地合并 2 个表,但是当我尝试合并第三个表时,查询无法执行。我已经单独测试了每个组合(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 查询并将它们合并在一起。所以问题显然在于我尝试联合 3 个查询,而不是 3 个表。想法?

谢谢!

【问题讨论】:

  • 您能否详细说明“执行失败”?你有错误吗?查询是否超时?
  • 你可以尝试只使用 UNION 而不是 UNION ALL 吗?
  • @Joe- 好问题。具体来说,我收到“ODBC--调用失败”(我通过 ODBC 链接到 MySQL)和错误“您的 SQL 语法有错误;请查看手册以了解在 UNION ALL 附近使用的正确语法...”
  • @Paul- 不,使用 UNION 或 UNION ALL 时出现同样的错误。
  • 正如 Paul McCowat 推测的那样,UNION 与 UNION AL 没有 Access/Jet/ACE 限制。 UNION 消除了欺骗,UNION ALL 没有。如果您知道每个 SELECT 返回的记录不重叠,则应始终使用 UNION ALL,因为它会快得多。也就是说,优先使用 UNION ALL,并且仅在您确定必须消除欺骗时才使用 UNION。

标签: mysql ms-access union-all


【解决方案1】:

我无法在 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

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

【讨论】:

  • Paul,感谢您测试和发布此代码 sn-p。我毫不怀疑它在 SQL Server 中工作,但有限的 Access SQL 功能不会接受这一点。它返回一个“操作查询不能用作行源”。我将继续研究其他选项,也许只是将其移至 MySQL 本机。就设计而言,我同意。这种需求源于之前实施的设计,他们可以将账单应用到“通用”实体,而不是将账单分配给 1 个实体,并且成本平均分配给多达 49 个实体。
  • 呃,您报告的错误表明您正在尝试在 SELECT 中使用 DML 查询,这是您无法做到的。也就是说,Paul 的 SQL 中没有任何内容是 DML 语句,因此不可能产生该错误,因此它表明您使用的内容完全不同。
【解决方案2】:

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

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;

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 2015-09-01
    • 1970-01-01
    • 2011-12-17
    • 1970-01-01
    • 2013-09-19
    • 1970-01-01
    • 1970-01-01
    • 2017-03-02
    相关资源
    最近更新 更多