oracle中的merge语句,Oracle 中MERGE语句的用法

MERGE语句是Oracle9i新增的语法,用来合并UPDATE和INSERT语句。通过MERGE语句,根据一张表或子查询的连接条件对另外一张表进行查询,连接条件匹配上的进行UPDATE,无法匹配的执行INSERT。这个语法仅需要一次全表扫描就完成了全部工作,执行效率要高于INSERT+UPDATE。

//表1

create table subs(msid number(9),

ms_type char(1),

areacode number(3)

);

//表2

create table acct(msid number(9),

bill_month number(6),

areacode   number(3),

fee        number(8,2) default 0.00);

//测试数据

insert into subs values(905310001,0,531);

insert into subs values(905320001,1,532);

insert into subs values(905330001,2,533);

commit;

一.下面先演示一下merge的基本功能

1) matched 和not matched clauses 同时使用

merge into acct a

using subs b on (a.msid=b.msid)

when MATCHED then

update set a.areacode=b.areacode

when NOT MATCHED then

insert(msid,bill_month,areacode)

values(b.msid,'200702',b.areacode);

2) 只有not matched clause,也就是只插入不更新

merge into acct a

using subs b on (a.msid=b.msid)

when NOT MATCHED then

insert(msid,bill_month,areacode)

values(b.msid,'200702',b.areacode);

3) 只有matched clause, 也就是只更新不插入

merge into acct a

using subs b on (a.msid=b.msid)

when MATCHED then

update set a.areacode=b.areacode

二.10g中增强一:条件操作

1) matched 和not matched clauses 同时使用

merge into acct a

using subs b on (a.msid=b.msid)

when MATCHED then

update set a.areacode=b.areacode

where b.ms_type=0

when NOT MATCHED then

insert(msid,bill_month,areacode)

values(b.msid,'200702',b.areacode)

where b.ms_type=0;

2) 只有not matched clause,也就是只插入不更新

merge into acct a

using subs b on (a.msid=b.msid)

when NOT MATCHED then

insert(msid,bill_month,areacode)

values(b.msid,'200702',b.areacode)

where b.ms_type=0;

3) 只有matched clause, 也就是只更新不插入

merge into acct a

using subs b on (a.msid=b.msid)

when MATCHED then

update set a.areacode=b.areacode

where b.ms_type=0;

三.10g中增强二:删除操作

merge into acct a

using subs b on (a.msid=b.msid)

when MATCHED then

update set a.areacode=b.areacode

delete where (b.ms_type!=0);

注意:

1.MERGE语句的UPDATE不能修改用于连接的列,否则会报错(on 后面的条件列就是联接)

2.using 后面可以是(SELECT msid ,areacode FROM subs GROUP by msid )

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值