Oracle 使用MERGE INTO 语句更新数据
2015-11-30 17:48
621 查看
/*Merge into 详细介绍
MERGE语句是Oracle9i新增的语法,用来合并UPDATE和INSERT语句。
通过MERGE语句,根据一张表或子查询的连接条件对另外一张表进行查询,
连接条件匹配上的进行UPDATE,无法匹配的执行INSERT。
这个语法仅需要一次全表扫描就完成了全部工作,执行效率要高于INSERT+UPDATE。
*/
/*语法:
MERGE [INTO [schema .] table [t_alias]
USING [schema .] { table | view | subquery } [t_alias]
ON ( condition )
WHEN MATCHED THEN merge_update_clause
WHEN NOT MATCHED THEN merge_insert_clause;
*/
MERGE语句是Oracle9i新增的语法,用来合并UPDATE和INSERT语句。
通过MERGE语句,根据一张表或子查询的连接条件对另外一张表进行查询,
连接条件匹配上的进行UPDATE,无法匹配的执行INSERT。
这个语法仅需要一次全表扫描就完成了全部工作,执行效率要高于INSERT+UPDATE。
*/
/*语法:
MERGE [INTO [schema .] table [t_alias]
USING [schema .] { table | view | subquery } [t_alias]
ON ( condition )
WHEN MATCHED THEN merge_update_clause
WHEN NOT MATCHED THEN merge_insert_clause;
*/
merge into users using doctoron (users.user_id = doctor.doctorid)when matched then update set users.user_name = doctor.doctornamewhen not matched then insert values (doctor.doctorid, doctor.doctorid, '8736F1C243E3B14941A59FF736E1B5A8', doctor.doctorname, sysdate, 'T', ' ', doctor.deptid, 'b319dac7-2c5c-496a-bc36-7f3e1cc066b8');
相关文章推荐
- oracle 启动的步骤
- Oracle大数据常见优化查询
- ORACLE 创建用户,表空间,导入导出实践
- 基于RHEL 6.5安装Oracle 11g详细教程(4)安装Oracle前的准备
- oracle 消除块竞争(hot blocks)
- oracle关键字使用
- mysql、oracle分页
- Oracle 12c迁移pluggable database到异库
- 【Loadrunner】LR中监控ORACLE数据库常用计数器(如何自定义Oracle计数器)
- Oracle接口开发之PL/SQL Gateway
- Mybatis Oracle 批量插入数据的方法
- 处理Oracle表无法导出的问题
- oracle和mysql mybatis批量更新
- 关于Oracle数据库表的锁定查看,解锁
- oracle开启audit(审计)
- oracle删除表空间
- oracle11g完全卸载办法
- Oracle 11g静默安装简明版
- Oracle 10g设置IP访问限制
- oracle-btree和bitmap索引