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

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日

悬赏问题

  • ¥15 想通过pywinauto自动电机应用程序按钮,但是找不到应用程序按钮信息
  • ¥15 MATLAB中streamslice问题
  • ¥15 如何在炒股软件中,爬到我想看的日k线
  • ¥15 51单片机中C语言怎么做到下面类似的功能的函数(相关搜索:c语言)
  • ¥15 seatunnel 怎么配置Elasticsearch
  • ¥15 PSCAD安装问题 ERROR: Visual Studio 2013, 2015, 2017 or 2019 is not found in the system.
  • ¥15 (标签-MATLAB|关键词-多址)
  • ¥15 关于#MATLAB#的问题,如何解决?(相关搜索:信噪比,系统容量)
  • ¥500 52810做蓝牙接受端
  • ¥15 基于PLC的三轴机械手程序