最佳答案
我有以下两张桌子:
Table1
----------
ID Name
1 A
2 B
3 C
Table2
----------
ID Name
1 Z
我需要插入数据从 Table1
到 Table2
。我可以使用以下语法:
INSERT INTO Table2(Id, Name) SELECT Id, Name FROM Table1
然而,在我的例子中,重复的 ID 可能存在于 Table2
中(在我的例子中,它只是“ 1
”) ,我不想再次复制它,因为那样会抛出一个错误。
我可以这样写:
IF NOT EXISTS(SELECT 1 FROM Table2 WHERE Id=1)
INSERT INTO Table2 (Id, name) SELECT Id, name FROM Table1
ELSE
INSERT INTO Table2 (Id, name) SELECT Id, name FROM Table1 WHERE Table1.Id<>1
不使用 IF - ELSE
有更好的方法吗?基于某些条件,我希望避免使用两个 INSERT INTO-SELECT
语句。