Oracle DB equivalent of on duplicate key update

后端 未结 3 1402
闹比i
闹比i 2020-12-06 06:52

I need to execute the following MySQL-query in Oracle:

INSERT INTO users VALUES(1,10) ON DUPLICATE KEY UPDATE points = 10;

Is there somethi

3条回答
  •  囚心锁ツ
    2020-12-06 07:24

    You would need to use a MERGE. Something like

    MERGE INTO users dest
      USING( SELECT 1 user_id, 10 points FROM dual) src
         ON( dest.user_id = src.user_id )
     WHEN MATCHED THEN
       UPDATE SET points = src.points
     WHEN NOT MATCHED THEN
       INSERT( user_id, points ) 
         VALUES( src.user_id, src.points );
    

提交回复
热议问题