在使用UNION处理查询时,有几个要点:
1、所有要进行UNION的查询,其SELECT列表中列的数量必须相同。如果第一个查询的列表中有3个列,那么第二个查询(以及所有进行UNION的后续查询)的SELECT列表也必须是3个列。
2、为合并的结果集返回的标头仅取自第一个查询。如果第一个查询的SELECT列表类似这样,SELECT Col1,Col2
AS Second,Col3 FROM...,那么无论后续的查询中列的名称或别名如何,UNION返回的列标头都将分别是Col1、Second以及Col3。
3、一个查询中每一列的数据类型必须与其他查询中相同对应的列的数据类型隐式兼容。注意:这里并不是一定要相同----它们只要能隐式转换即可。如果第一个查询中第二列的数据类型是char(20),那么第二个查询中第二列的数据类型是varchar(30)是可以的。然而,由于一切都是基于第一个查询,因此结果集中第二列所有长度超过20的行将被截断。
4、与非UNION的查询不同,UNION的默认返回方式是DISTINCT而非ALL。在其他的查询中,所有行都将被返回,无论它们是否与别的行有重复,而UNION却不是这样的。除非在查询中使用了ALL关键字,否则只返回一个有重复的行。