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
服务器部署程序员系统优化网站设置运维相关文章
- Fabric.js 使用纯色遮挡画布(前景色)
- 大多数程序员都懂的java虚拟机:C1编译器从字节码到HIR
- Scratch3.0——助力新进程序员理解程序(案例一、画画的蝴蝶)
- rhel 6.x 使用 udev scsi rules 配置裸设备详解程序员
- bash shell数组使用总结详解程序员
- IIS7.5使用web.config设置伪静态的方法详解程序员
- XX-Net使用详解程序员
- ubuntu12.04 使用wireshark详解程序员
- 安装使用lvs详解程序员
- SCons的使用详解程序员
- linux 使用java编写ssh登陆主机 输入密码登陆并执行命令(jsch)详解程序员
- LINUX下使用Shell自动监控tomcat并且执行重启操作详解程序员
- 灵活使用rewrite详解程序员
- linux下使用软连接之案例二详解程序员
- Maven学习 (三) 使用m2eclipse创建web项目详解程序员
- SQL时间戳的使用详解程序员
- [Linux] PHP程序员玩转Linux系列-怎么安装使用详解编程语言
- PHP程序员应该使用的10个组件