我有2个表-每个表只有一行。我想用表2中的相应列更新表1上的o1和o2列。
create table Table1(c1 int, c2 int, o1 int, o2 int)
create table Table2(o1 int, o2 int)
我有以下内容,这很可怕(但有效)。
update Table1
set o1 = (select o1 from Table2),
o2 = (select o2 from Table2)
有更好的方法吗?
答案 0 :(得分:1)
您可以使用:
update table1
set o1 = t2.o1,
o2 = t2.o2
from table2 t2;
答案 1 :(得分:1)
通过这种方式,即使有1行或'n'行,您也可以按预期进行操作-
UPDATE T1
SET T1.o1 = T2.o1,
T1.o2 = T2.o2
from table1 T1 INNER JOIN table2 T2 ON T1.o1=T2.o1 AND T1.o2=T2.o2;