我有以下两张表:
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
语句.