一:merge into的形式
MERGE INTO [target-table] A USING [source-table sql] B ON([conditional expression] and [...]...)
WHEN MATCHED THEN
[UPDATE sql]
WHEN NOT MATCHED THEN
[INSERT sql]
二:作用
判断B表和A表是否满足on条件,如果满足则用B表去更新A表,如果不满足,则将B表数据插入A表,但有很多可选项。
例如:
1:正常模式
2:只update或者只insert
3:带条件的update或带条件的insert
4:全插入insert实现
5:带delete的update -------------------不做讲解
三:正常模式
例如:
1:创建表A_MERGE
create table A_MERGE
(
id NUMBER not null,
name VARCHAR2(12) not null,
year NUMBER
);
2:创建表B_MERGE
create table B_MERGE
(
id NUMBER not null,
aid NUMBER not null,
name VARCHAR2(12) not null,
year NUMBER,
city VARCHAR2(12)
);
3:向A_MERGE和B_MERGE插入测试数据
insert into A_MERGE values(1,‘liuwei‘,20);
insert into A_MERGE values(2,‘zhangbin‘,21);
insert into A_MERGE values(3,‘fuguo‘,20);
commit;
insert into B_MERGE values(1,2,‘zhangbin‘,30,‘吉林‘);
insert into B_MERGE values(2,4,‘yihe‘,33,‘黑龙江‘);
insert into B_MERGE values(3,3,‘fuguo‘,‘‘,‘山东‘);
commit;
4:MERGE INTO A_MERGE A
USING (select B.AID,B.NAME,B.YEAR from B_MERGE B) C
ON (A.id=C.AID)
WHEN MATCHED THEN
UPDATE SET A.YEAR=C.YEAR
WHEN NOT MATCHED THEN
INSERT(A.ID,A.NAME,A.YEAR) VALUES(C.AID,C.NAME,C.YEAR);
commit;
5:解析
a:被更新的表写在MEGER INTO之后
b:更新来源数据表写在USING之后,并将相关字段查询出来,为查询结果定义别名
c:ON之后表示更新满足的条件
d:WHEN MATCHED THEN:表示当满足条件时要执行的操作。
e:UPDATE SET 被更新表.被更新字段 = 更新表.更新字段---此更新语句不同于常规更新语句
f:WHEN NOT MATCHED THEN:表示当不满足条件时要执行的操作。
g:INSERT (被更新表.被更新字段,...) VALUES(更新表.更新字段,...)。
h:commit:表示提交事务
四:只update或只insert
原文:https://www.cnblogs.com/zhaoja/p/11334544.html