lqbr123 2023-03-14 09:28 采纳率: 50%
浏览 19
已结题

UNION ALL的相关问题


SELECT TD027, COUNT(*) AS cnt FROM COPTD UNION ALL SELECT TC052  FROM COPTC GROUP BY TD027 HAVING COUNT(*) >1

这段代码怎么无法执行提示错误消息 8120,级别 16,状态 1,第 1 行
选择列表中的列 'COPTD.TD027' 无效,因为该列没有包含在聚合函数或 GROUP BY 子句中。
消息 205,级别 16,状态 1,第 1 行
使用 UNION、INTERSECT 或 EXCEPT 运算符合并的所有查询必须在其目标列表中有相同数目的表达式。

  • 写回答

2条回答 默认 最新

  • 码农学长 2023-03-14 09:45
    关注

    这段代码无法执行的原因是在 UNION ALL 运算符合并的两个查询中,目标列表中的列数不同。在第一个查询中,目标列表中有两列(TD027和cnt),而在第二个查询中,目标列表中只有一列(TC052)。这会导致 UNION ALL 运算符无法将两个查询的结果合并起来,从而引发错误消息。

    另外,在第二个查询中,使用了 GROUP BY 子句,但却没有在目标列表中包含聚合函数或分组列。这也会导致错误消息。
    望采纳,谢谢!

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 3月22日
  • 已采纳回答 3月14日
  • 创建了问题 3月14日