在MS-SQL如果将两个或更多查询的结果组合为单个结果集,该结果集包含联合查询中的所有查询的全部行,常用的方法如下:
一. 使用union 或union All语句
1. union 与 union all语句的区别
Ø UNION 组合多个表(或结果集)并将其作为单个结果集返回;
Ø UNION ALL 在结果中包含所有的行,包括重复行。
Ø 也就是说,使用UNION组合两个表时,将重复的记录删除;而使用UNION ALL组合两多个表时,不考虑结果集中是否存在重复记录。
2. 使用 UNION 运算符时请注意:
Ø 所有查询中的列数和列的顺序必须相同。
在使用 UNION 运算符组合的语句中,所有显示列表的数目必须相同(列表内容可以包括:列名、算术表达式、聚合函数等);
Ø 数据类型必须兼容。
在使用 UNION 组合的结果集中的相应列必须具有相同数据类型,或者两种数据类型之间存在隐性数据转换,或提供了类型转换。例如,在datetime 数据类型的列和 binary 数据类型的列之间不可能存在 UNION 运算符,除非提供了显式转换,而在 money 数据类型的列和 int 数据类型的列之间可以存在 UNION 运算符,因为它们可以进行隐性转换。
Ø 用 UNION 运算符组合的各语句中对应的结果集列出现的顺序必须相同,因为 UNION 运算符是按照各个查询给定的顺序逐个比较各列。
3. 与其它 Transact-SQL语句一起使用 UNION 语句时,应注意:
Ø 如果在有UNION的语句中使用INTO语句,则只能在最终表(或结果集)中使用,如果要在单个表(或结果集)中使用INTO语句,MS-SQL将会提示错误;
错误语句:Select AID,AName,ADemo Into From ATable Union All Select BID,BName,BDemo Into From BTable
Ø 只有在 UNION 语句的结尾,才允许使用 ORDER BY 和 COMPUTE 子句以定义最终结果的顺序或计算汇总值。不能在组建 UNION 语句的单独查询中使用这些子句。
错误语句:
Select AID,AName,ADemo From ATable order by AID Union All Select BID,BName,BDemo From BTable Order By BID |
可以这样写:
Select * From (Select AID,AName,ADemo From ATable Union All Select BID,BName,BDemo From BTable) a Order By a.AID |