我通过以下方式制作了一张临时表:
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语句的两个结果的正确语法。
任何帮助都会很棒!
答案 0 :(得分:10)
用逗号分隔的两个select命令不是有效的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
只能使用with
制作一个子查询,但我将它们都用来证明能够根据需要添加任意数量的表的灵活性。
请注意,列出您要插入的表格的所有列是一个非常好的做法,
e.g. `insert into return_table (p1, p2, p3, p4, p5, p6, p7) ...`
如果养成习惯,你会避免很多潜在的麻烦和麻烦。
另请注意,如果两个子查询中的任何一个返回不同于一个的行数,则上面的示例(以及它的等效连接)可能会产生质朴的结果
答案 1 :(得分:0)
没有一个实例可以用来测试它,但是如果你在select语句之间添加'UNION'会怎样,那么它会回来一个结果集呢?