gpt4 book ai didi

postgresql - 在 postgresql 中将两个 select 语句添加到一个 insert into 语句中

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

我通过以下方式制作了一个临时表:

create temporary table return_table 
(
p1 BIGINT,
p2 VARCHAR(45),
p3 VARCHAR(45),
p4 VARCHAR(45),
p5 VARCHAR(45),
p6 float,
p7float
) on commit drop;

我正在尝试采用 2 个选择语句并将数据插入到该临时表中。例如,我有一个名为 t1 的表,它提供了前四个值,然后我希望临时表的接下来的 3 个值来自另一个表。

到目前为止我有:

insert into return_table 
(Select var1, var2, var3, var4
from t1 where var1 = 10)

这将成功地将 4 个值放入我的临时表中,然后将其余值保留为空。很好,所以当我尝试从另一个表插入最后三个变量时。例如

insert into return_table 
(Select var1, var2, var3, var4
from t1 where var1 = 10, Select var5, var6, var 7
from t2 where var6 = 25)

它抛出语法错误。我已经尝试了一些其他的语法更改,但我无法找出将这些 select 语句的两个结果插入同一行的正确语法。

任何帮助都会很棒!

最佳答案

用逗号分隔的两个选择命令不是有效的 SQL 语法。您可以改用 joinwith 语句。这是一个 with

的例子
insert into return_table 
WITH t1 AS (
Select var1, var2, var3, var4 from t1 where var1 = 1
), t2 AS (
Select var5, var6, var7 from t2 where var6 = 6
)
select t1.var1, t1.var2, t1.var3, t1.var4, t2.var5, t2.var6, t2.var7 from t1,t2

一个人只能用 with 进行一个子查询,但我把它们都放在一起是为了展示能够根据需要添加尽可能多的表的灵 active 。

请注意,列出要插入的表的所有列是一个很好的做法,

e.g. `insert into return_table (p1, p2, p3, p4, p5, p6, p7) ...`

如果养成习惯,您将避免很多潜在的麻烦和头痛。

另请注意,如果两个子查询中的任何一个返回的行数不同于一个,则上面的示例(以及它的等效连接)可能会产生奇怪的结果

关于postgresql - 在 postgresql 中将两个 select 语句添加到一个 insert into 语句中,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20426967/

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