用逗号分隔的两个 select 命令不是有效的 SQL 语法。您可以使用join
or 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) ...`
如果你养成习惯,你会避免很多潜在的麻烦和头痛。
另请注意,如果两个子查询中的任何一个返回的行数不同于一个,则上面的示例(及其等效的连接)可能会产生奇怪的结果