我有以下两个表:
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
”),我不想再次复制该ID ,因为这会引发错误。
我可以这样写:
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
基于某些条件的两个语句。