Sqlserver
 sql >> Baza danych >  >> RDS >> Sqlserver

składnia pojedynczego wiersza MERGE / upsert w SQL Server

w końcu dostałem składnię Upsert za pomocą MERGE w SQL Server 2008. Korzystanie z tego, czego Jacob chciał do zrobienia (Upsert):

IF EXISTS(SELECT * FROM member_topic WHERE mt_member = 0 AND mt_topic = 110)
BEGIN
    --update existing row
    UPDATE member_topic SET mt_notes = 'test'
    WHERE mt_member = 0
    AND mt_topic = 110
END
ELSE
BEGIN
    --insert new row
    INSERT INTO member_topic (mt_member, mt_topic, mt_notes)
    VALUES (0, 110, 'test')
END

Odpowiednik MERGE składnia to:

MERGE member_topic
USING ( 
    VALUES (0, 110, 'test')
) AS foo (mt_member, mt_topic, mt_notes) 
ON member_topic.mt_member = foo.mt_member 
   AND member_topic.mt_topic = foo.mt_topic
WHEN MATCHED THEN
   UPDATE SET mt_notes = foo.mt_notes
WHEN NOT MATCHED THEN
   INSERT (mt_member, mt_topic, mt_notes)
   VALUES (foo.mt_member, foo.mt_topic, foo.mt_notes)
; --A MERGE statement must be terminated by a semi-colon (;).


  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Zapytanie SQL, aby uzyskać zagregowany wynik w separatorach przecinków wraz z grupowaniem po kolumnie w SQL Server

  2. Jak dodać ograniczenie klucza obcego do istniejącej tabeli w SQL Server — samouczek SQL Server / TSQL część 68

  3. SQL Server CTE i przykład rekurencji

  4. Dodaj domyślną wartość pola datetime w SQL Server do znacznika czasu

  5. Pobierz datę rozpoczęcia tygodnia i datę zakończenia tygodnia z numeru tygodnia