zl程序教程

您现在的位置是:首页 >  其他

当前栏目

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

程序员 使用 详解 语句 INTO Merge
2023-06-13 09:20:21 时间

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

服务器部署程序员系统优化网站设置运维