Sqlserver
 sql >> Database >  >> RDS >> Sqlserver

SQL Server 2005, AGGIORNAMENTO in blocco o INSERT

Blog di Alex Kuznetsov contiene un suggerimento utilizzando il OUTPUT clausola di un UPDATE dichiarazione. Per parafrasare l'esempio di quel post di blog (non testato):

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)