根据与源表相联接的结果,对目标表进行插入、更新、删除等操作。 例如,对目标表,如果源表存在的数据则更新,没有的则插入,就可以使用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可以快捷的实现