没有什么共同之处时,如何从表2更新表1?

时间:2019-10-02 17:59:59

标签: sql sql-server sql-server-2017

我有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)

有更好的方法吗?

2 个答案:

答案 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;