使用表别名UPSERT来自另一个数据库的表

时间:2017-01-12 13:32:07

标签: sql sql-server database

我有两个具有相同表但数据不同的数据库。我想从第二个数据库中的表中获取所有数据,并更新第一个数据库中的现有值。

如果没有这样的条目,我想插入新的条目。 这是我的代码(不起作用):

UPDATE tbl1
SET tbl1.Field1 = tbl2.Field1 
FROM [test1].[dbo].[Table1] tbl1, [test2].[dbo].[Table1] tbl2
WHERE tbl1.Id = tbl2.Id

IF @@ROWCOUNT = 0
    INSERT INTO tbl1 (tbl1.Id, tbl1.Field1) 
    VALUES ([test2].[dbo].[Table1].Id, [test2].[dbo].[Table1].Field1)

我有以下错误消息。

  

Msg 4104,Level 16,State 1,Line 9
  无法绑定多部分标识符“test2.dbo.Table1.Id”。

     

Msg 4104,Level 16,State 1,Line 9
  无法绑定多部分标识符“test2.dbo.Table1.Field1”。

我认为问题在于别名使用错误,但我无法弄清楚我到底做错了什么。

2 个答案:

答案 0 :(得分:6)

您可以使用MERGE语句:

Merge   [test1].[dbo].[Table1]  As Target
Using   [test2].[dbo].[Table1]  As Source   On  Target.Id = Source.Id
When Matched Then Update
    Set Field1 = Source.Field1
When Not Matched Then Insert
        (Id, Field1)
Values  (Source.Id, Source.Field1);

答案 1 :(得分:1)

问题是你正在使用

INSERT INTO tbl1 (tbl1.Id, tbl1.Field1) 
VALUES ([test2].[dbo].[Table1].Id, [test2].[dbo].[Table1].Field1)

在此语句中,只能使用常量或变量。

但你可能需要像那样使用......

INSERT INTO [test2].[dbo].[Table1] (Id, Field1) 
SELECT tbl2.Id, tbl2.Field1 FROM [test1].[dbo].[Table1] tbl1 
WHERE NOT EXISTS(
    SELECT * FROM [test2].[dbo].[Table1] tbl2 WHERE tbl2.ID=tbl1.ID
)