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

Sup*_*one 3 postgresql select stored-procedures

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

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;
Run Code Online (Sandbox Code Playgroud)

我试图采取2个选择语句并将数据插入该临时表.例如,我有一个名为t1的表,它提供前四个值,然后我希望临时表的后三个值来自另一个表.

到目前为止,我有:

insert into return_table 
(Select var1, var2, var3, var4 
 from t1 where var1 = 10)
Run Code Online (Sandbox Code Playgroud)

这将成功地将4个值放入我的临时表中,然后将其余值保留为null.那没关系,所以当我尝试从另一个表中插入最后三个变量时.例如

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

它会引发语法错误.我已经尝试了一些其他的语法更改,但我无法弄清楚在同一行中插入这些select语句的两个结果的正确语法.

任何帮助都会很棒!

foi*_*ibs 10

由逗号分隔的两个选择命令不是有效的SQL语法.您可以使用join或使用with语句.这是一个例子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
Run Code Online (Sandbox Code Playgroud)

一个人只能制作一个子查询,with但我把它们都用来证明能够根据需要添加任意数量的表的灵活性.

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

e.g. `insert into return_table (p1, p2, p3, p4, p5, p6, p7) ...`
Run Code Online (Sandbox Code Playgroud)

如果你养成习惯,你会避免很多潜在的麻烦和头痛.

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