SQL 高階語法 MERGE INTO

LearnerPing發表於2024-09-11

根據與源表相聯接的結果,對目標表進行插入、更新、刪除等操作。 例如,對目標表,如果源表存在的資料則更新,沒有的則插入,就可以使用MEREG進行同步。

基本語法

MERGE INTO target_table
USING source_table
ON condition
WHEN MATCHED THEN 
XXX
WHEN NOT MATCHED THEN 
XXX

這裡的Source table 不限於單獨的表格,也可以是子查詢的內容

示例

INSERT tbl_A (col, col2)
SELECT col, col2
FROM tbl_B
WHERE NOT EXISTS (SELECT col FROM tbl_A A2 WHERE A2.col = tbl_B.col);

上面的SQL是為了向 tbl_A 中插入 tbl_B 含有的,但是 tbl_A 不包含的col
改為MERGE可以寫為

MERGE INTO tbl_A  t  
    USING tbl_B v  
    ON t.col = v.col  
    WHEN MATCHED THEN   
        UPDATE SET y.c2 = v.c2  
    WHEN NOT MATCHED THEN  
        INSERT (col, col2) VALUES (v.c1, v.c2);

(這裡為了展示更多的選項,加多了一句UPDATE)
當一個表需要依託於另一個表進行更新操作的時候,使用MERGE可以快捷的實現

相關文章