oracle merge into命令

Oracle merge into命令,顾名思义就是“有则更新,无则插入”,这个也是merge into 命令的核心思想,在实际开发过程中,我们会经常遇到这种通过两表互相关联匹配更新其中一个表的某些字段的业务,有时还要处理不匹配的情况下的业务。这个时候你会发现随着表的数据量增加,类似这种业务场景的执行效率会比较慢,那是因为你需要多次重复查询两表中的数据,而通过merge into命令,只需要一次关联即可完成“有则更新,无则插入”的业务场景,大大提高语句的执行效率。

merge into命令的语法结构如下:

merge into A 
using B 
on (A.id = B.id)
when matched then
  update set A.col=B.col
when not matched then
  insert 语句;

语法解析:利用B表通过A.id=B.id的条件来匹配A表,当满足条件时,可以对A表进行更新,当不满足条件时,可以利用inert语句插入相关数据。

例子:利用merge into命令从学生表(stuinfo)更新学生备份表(stuinfo_2018)的年龄,当备份表中找不到学生信息时插入新的学生信息,先看下两张表的数据:

oracle merge into命令

具体代码如下:

merge into student.stuinfo_2018 A --
using student.stuinfo B 
on (A.stuid = B.stuid)
when matched then
  update set A.age=B.age
when not matched then
  insert (a.STUID,a.STUNAME,a.SEX,a.AGE,a.CLASSNO,a.STUADDRESS,a.GRADE,a.ENROLDATE,a.IDNUMBER
) values(b.STUID,b.STUNAME,b.SEX,b.AGE,b.CLASSNO,b.STUADDRESS,b.GRADE,b.ENROLDATE,b.IDNUMBER);

再看下备份表的数据,发现已经按照我们意愿添加了新的学生和变更了学生的年龄。如下:

oracle merge into命令