10.5. UNION
, CASE
和相关构造
SQL UNION
构造必须把那些可能不太相似的类型匹配起来成为一个结果集。 解析算法分别应用于联合查询的每个输出字段。INTERSECT
和EXCEPT
构造对不相同的类型使用和 UNION
相同的算法进行解析。 CASE
, ARRAY
, VALUES
, GREATEST
, 和LEAST
构造也使用同样的算法匹配它的部件表达式并且选择一个结果数据类型。
UNION
, CASE
和相关构造的类型解析
如果所有输入都是相同的类型,并且不是
unknown
类型,那么解析成这种类型。 否则,用它们潜在的基本类型替换列表中的域类型。如果所有输入都是
unknown
类型则解析成text
类型 (字符串类型范畴的首选类型)。否则,忽略unknown
输入。如果非 unknown 输入不属于同一个类型范畴,失败。
如果有,则选取第一个属于该范畴中首选类型的非 unknown 输入类型。
否则,选择最后一个允许所有前面的非unknown输入隐式转换为它的非unknown输入类型。 (总是有这么一种类型,因为至少列表上的第一种类型必须适合这种情况。)
把所有输入转换为所选的类型。如果从给定的输入到所选的类型没有一个转换则失败。
下面是一些例子。
Example 10-8. Union中的待定类型解析
SELECT text 'a' AS "text" UNION SELECT 'b';
text
------
a
b
(2 rows)
这里,unknown 类型文本'b'
将被解析成text
类型。
Example 10-9. 简单Union中的类型解析
SELECT 1.2 AS "numeric" UNION SELECT 1;
numeric
---------
1
1.2
(2 rows)
文本1.2
的类型为numeric
,而且integer
类型的1
可以隐含地转换为numeric
,因此使用这个类型。
Example 10-10. 转置Union中的类型解析
SELECT 1 AS "real" UNION SELECT CAST('2.2' AS REAL);
real
------
1
2.2
(2 rows)
这里,因为类型real
不能被隐含转换成integer
,但是integer
可以隐含转换成real
,那么联合的结果类型将是real
。