Sqlserver
 sql >> Base de Dados >  >> RDS >> Sqlserver

SQL Server 2005, UPDATE ou INSERT em massa


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)