Share to: share facebook share twitter share wa share telegram print page

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 ...]);

Voorbeeld

Om 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 ook

  • (en) MERGE MSDN-documentatie
  • (en) Introduction to the MERGE Statement Essential SQL
  • (en) MERGE Statement PostgreSQL documentatie
Kembali kehalaman sebelumnya