使用 MERGE INTO 语法可合并 UPDATE 和 INSERT 语句。通过 MERGE 语句,根据一 张表(或视图)的连接条件对另外一张表(或视图)进行查询,连接条件匹配上的进行 UPDATE (可能含有 DELETE),无法匹配的执行 INSERT。
用法:Insert/Update
有一个表T(指a),有两个字段a、b,我们想在表T中做Insert/Update,如果条件满足,则更新T中b的值,否则在T中插入一条记录。
merge into 目标表 a
using 源表 b
on(a.条件字段1=b.条件字段1 and a.条件字段2=b.条件字段2 ……)
when matched then update set a.字段=b.字段 where(条件)--目标表别称a和源表别称b都不要省略
when not matched then insert (a.字段1,a.字段2……)values(b.字段1,b.字段2……) --目标表别称a可省略,源表别称b不可省略
"在一个同时存在Insert和Update语法的Merge语句中,总共Insert/Update的记录数,就是Using语句中"源表"的记录数"。
使用说明:
1.INTO 后为目标表,表示待更新、插入的表、可更新视图及可更新查询表达式;
2.USING 后为源表(普通表或可更新视图),表示用于和目标表匹配、更新或插入的 数据源; 3.ON ()表示目标表和源表的连接条件,如果目标表有匹配连接条 件的记录则执行更新该记录,如果没有匹配到则执行插入源表数据;
4.插入的 where 条件只能包含源表列。