merge into Oracle里的 saveOrUapdate
1、初始数据:
SQL> select * from a; ID NAME ---------------------- ---------------------- 1 1 2 1 3 1 4 1 5 1 SQL> select * from b; ID NAME ---------------------- ---------------------- 1 2 2 2 11 11
2、目标:1)a表中id与b表中id一样的话,更新a.name以b.name为准;2)b表中id不在a表中的话,复制b表的记录,插入到a表中
3、功能实现:
merge into A a using B b on (a.id = b.id) --on为匹配条件 when matched then --匹配时 更新a.name update set a.name = b.name where 1=1 --这里可以添加where条件 when not matched then --不匹配时 复制并插入b insert values(b.id,b.name) where 1=1
郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。