oracle中merge into..using..on..when..when..用法

语法:

MERGE INTO [your table-name] [rename your table here]   
  
USING ( [write your query here] )[rename your query-sql and using just like a table]   
  
ON ([conditional expression here] AND [...]...)   
  
WHEN MATHED THEN [here you can execute some update sql or something else ]   
  
WHEN NOT MATHED THEN [execute something else here ! ]  

 

实例:

merge into tfa_alarm_act_nms a   
using (select FP0,FP1,FP2,FP3,REDEFINE_SEVERITY   
from tfa_alarm_status) b   
on (a.fp0=b.fp0 and a.fp1=b.fp1 and a.fp2=b.fp2 and a.fp3=b.fp3)   
when matched then update set a.redefine_severity=b.redefine_severity   
when not matched then insert (a.fp0,a.fp1,a.fp2,a.fp3,a.org_severity,a.redefine_severity,
a.event_time  ,a.int_id)   
values (b.fp0,b.fp1,b.fp2,b.fp3,b.REDEFINE_SEVERITY,b.redefine_severity,sysdate,7777778);  

 

 

作用:利用表 tfa_alarm_status跟新表tfa_alarm_act_nms 的b.redefine_severity,条件是a.fp0=b.fp0 and a.fp1=b.fp1 and a.fp2=b.fp2 and a.fp3=b.fp3,如果tfa_alarm_act_nms表中没有该条件的数据就插入。

如果你的数据量很大,此sql效率非常高。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值