merge into 语句的使用详解程序员

MERGE语句是Oracle9i新增的语法,用来合并UPDATE和INSERT语句。

  通过MERGE语句,根据一张表或子查询的连接条件对另外一张表进行查询,

  连接条件匹配上的进行UPDATE,无法匹配的执行INSERT。

  这个语法仅需要一次全表扫描就完成了全部工作,执行效率要高于INSERT+UPDATE。

语法

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 ! ]

1、UPDATE或INSERT子句是可选的

2、UPDATE和INSERT子句可以加WHERE子句

3、在ON条件中使用常量过滤谓词来insert所有的行到目标表中,不需要连接源表和目标表

4、UPDATE子句后面可以跟DELETE子句来去除一些不需要的行

——-实例——-

merge into  a 
using (select id,name from b ) c 
on(a.id=c.id ) 
when matched  
   then  
      update set a.name=c.name 
when not matched  
   then  
      insert (a.id,a.name) values (c.id,c.name); 
 
 

作用:利用表 b 跟新表a ,条件是a.id=b.id,如果a表中没有该条件的数据就插入。

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

merge into也是一个dml语句,和其他的dml语句一样需要通过rollback和commit 结束事务。

原创文章,作者:Maggie-Hunter,如若转载,请注明出处:https://blog.ytso.com/7270.html

(0)
上一篇 2021年7月17日
下一篇 2021年7月17日

相关推荐

发表回复

登录后才能评论