![](/img/trans.png)
[英]SQL: CROSS JOIN UNNEST and include data from rows with NULLs in CROSS JOIN UNNEST column
[英]Column definitions in ROWS FROM() with multiple unnest calls
我想在select子句中使用多个数组。 明显的一个没有用,postgresql指向ROWS FROM()
...
select * from unnest(array[1,2], array[3,4]) as (a int, b int);
错误:
UNNEST() with multiple arguments cannot have a column definition list
LINE 1: select * from unnest(array[1,2], array[3,4]) as (a int, b in...
^
HINT: Use separate UNNEST() calls inside ROWS FROM(), and attach a column definition list to each one.
...
select * from rows from (unnest(array[1,2]), unnest(array[3,4])) as (a int, b int);
错误:
ROWS FROM() with multiple functions cannot have a column definition list
LINE 1: ...from (unnest(array[1,2]), unnest(array[3,4])) as (a int, b i...
^
HINT: Put a separate column definition list for each function inside ROWS FROM().
该手册也解释了这一点,但如何定义这些“单独的列定义”?
您可以使用AS t(a, b)
定义不带类型的列名:
#= SELECT * FROM unnest(array[1,2], array[3,4,5]) AS t(a, b);
a | b
---+---
1 | 3
2 | 4
∅ | 5
要定义类型,请在数组本身上执行:
#= SELECT a / 2 AS half_a, b / 2 AS half_b
FROM unnest(array[1,2]::float[], array[3,4,5]::integer[]) AS t(a, b);
half_a | half_b
--------+--------
0.5 | 1
1 | 2
∅ | 2
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.