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

时间:2013-12-06 14:57:53

标签: 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;

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

到目前为止,我有:

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

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

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语句的两个结果的正确语法。

任何帮助都会很棒!

2 个答案:

答案 0 :(得分:10)

用逗号分隔的两个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制作一个子查询,但我将它们都用来证明能够根据需要添加任意数量的表的灵活性。

请注意,列出您要插入的表格的所有列是一个非常好的做法,

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

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

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

答案 1 :(得分:0)

没有一个实例可以用来测试它,但是如果你在select语句之间添加'UNION'会怎样,那么它会回来一个结果集呢?