gpt4 book ai didi

sql - 具有多个 unnest 调用的 ROWS FROM() 中的列定义

转载 作者:行者123 更新时间:2023-11-29 11:31:38 27 4
gpt4 key购买 nike

我想在一个 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

关于sql - 具有多个 unnest 调用的 ROWS FROM() 中的列定义,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34709018/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com