使用INNER JOIN更新SQL Server中的多个表

时间:2013-02-27 15:22:24

标签: sql sql-server tsql

我正在使用SQL Server并尝试使用SQL一次更新多个表:

以下查询:

update table1
set A.ORG_NAME =  @ORG_NAME, B.REF_NAME = @REF_NAME
from table1 A, table2 B
where B.ORG_ID = A.ORG_ID
and A.ORG_ID = @ORG_ID

给出错误消息:

  

无法绑定多部分标识符“A.ORG_NAME”。

错误消息是什么意思?

2 个答案:

答案 0 :(得分:29)

您无法在单个语句中更新一个表,但是您收到的错误消息是由于别名,您可以尝试这样做:

BEGIN TRANSACTION

update A
set A.ORG_NAME =  @ORG_NAME
from table1 A inner join table2 B
on B.ORG_ID = A.ORG_ID
and A.ORG_ID = @ORG_ID

update B
set B.REF_NAME = @REF_NAME
from table2 B inner join table1 A
    on B.ORG_ID = A.ORG_ID
    and A.ORG_ID = @ORG_ID

COMMIT

答案 1 :(得分:12)

如果您只影响一个表,则可以使用联接进行更新:

UPDATE table1 
SET table1.name = table2.name 
FROM table1, table2 
WHERE table1.id = table2.id 
AND table2.foobar ='stuff'

但是您尝试使用连接多个表的更新语句来影响多个表。这是不可能的。

但是,实际上可以在一个语句中更新两个表,但需要使用包含要更新的表的UNION创建一个View。然后,您可以更新View,然后更新基础表。

SQL JOINS

但这是一个非常hacky的客厅技巧,使用交易和多个更新,它更直观。