我有两个具有相同表但数据不同的数据库。我想从第二个数据库中的表中获取所有数据,并更新第一个数据库中的现有值。
如果没有这样的条目,我想插入新的条目。
这是我的代码(不起作用):
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
”。
我认为问题在于别名使用错误,但我无法弄清楚我到底做错了什么。
答案 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
)