blog de Alex Kuznetsov contém uma sugestão usando o
OUTPUT
cláusula de um UPDATE
declaração. Para parafrasear o exemplo dessa entrada de blog (não testado):DECLARE @updated_ids table(id int)
UPDATE table
SET ...
OUTPUT inserted.id INTO @updated_ids
FROM table INNER JOIN data-to-insert ON table.id = data-to-insert.id
INSERT INTO table
SELECT ...
FROM data-to-insert
WHERE id NOT IN (SELECT id FROM @updated_ids)