Merge (SQL)Een MERGE-opdracht in SQL wordt gebruikt in combinatie met INSERT en UPDATE voor het invoegen en/of bijwerken van bestaande records afhankelijk van de opgegeven conditie. Een niet-bestaand record in een tabel wordt ingevoegd (INSERTed) of, als het record wel bestaat, worden de gegevens ervan bijgewerkt (UPDATEd). Het werd voor het eerst geïntroduceerd in de SQL:2003-standaard, en later uitgebreid in de SQL:2008-standaard. Het MERGE-statement is met name praktisch bij het uitvoeren van meerdere INSERT en UPDATE instructies omdat er slechts een instructie gebruikt hoeft te worden. Sommige implementaties gebruiken de term 'Upsert', een porte-manteau van Update en Insert. Dit synoniem wordt toegepast in SQLite en Microsoft Azure SQL. Gebruik MERGE INTO doeltabel USING brontabel ON (conditie)
WHEN MATCHED THEN
UPDATE SET kolom1 = waarde1 [, kolom2 = waarde2 ...]
WHEN NOT MATCHED THEN
INSERT (kolom1 [, kolom2 ...]) VALUES (waarde1 [, waarde2 ...]);
VoorbeeldOm aantallen bij te werken of in te voegen in de tabel 'verkoop' waarbij het artikelID gelijk is, gebruikt men: MERGE INTO verkoop USING producten ON (producten.artikelID = verkoop.artikelID)
WHEN MATCHED THEN
UPDATE SET aantal = 50
WHEN NOT MATCHED THEN
INSERT (aantal) VALUES (50);
Zie ookExterne links
|