Oracle 使用MERGE INTO 语句更新数据

纵然是瞬间 提交于 2019-12-16 17:48:32

【推荐】2019 Java 开发者跳槽指南.pdf(吐血整理) >>>

/*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 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');

复制代码


标签
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!