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 运算符合并的所有查询必须在其目标列表中有相同数目的表达式。

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

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

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

很明显,上下两个表列数不一样,无法对齐

UNION ALL语句查询多个表,然后把它们纵向连接在一起,变成一个表
所有的表列数必须一样才能对齐,不能有的2列有的1列