`

Oracle Merge into介绍

 
阅读更多

转自:http://smallnetvisitor.iteye.com/blog/1839107

 

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

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

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

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

语法:

Java代码  收藏代码
  1. MERGE INTO [your table-name] [rename your table here]  
  2.   
  3. USING ( [write your query here] )[rename your query-sql and using just like a table]  
  4.   
  5. ON ([conditional expression here] AND [...]...)  
  6.   
  7. WHEN MATHED THEN [here you can execute some update sql or something else ]  
  8.   
  9. WHEN NOT MATHED THEN [execute something else here ! ]  

 应用:

在创建另两个表fzq1和fzq2

--全部男生记录

Java代码  收藏代码
  1. create table fzq1 as select * from fzq where sex=1;  

 --全部女生记录

Java代码  收藏代码
  1. create table fzq2 as select * from fzq where sex=0;  

 涉及到两个表关联的例子

--更新表fzq1使得id相同的记录中chengji字段+1,并且更新name字段。

--如果id不相同,则插入到表fzq1中.

--将fzq1表中男生记录的成绩+1,女生插入到表fzq1中

Java代码  收藏代码
  1. merge into fzq1  aa     --fzq1表是需要更新的表  
  2. using fzq bb            -- 关联表  
  3. on (aa.id=bb.id)        --关联条件  
  4. when matched then       --匹配关联条件,作更新处理  
  5. update set  
  6. aa.chengji=bb.chengji+1,  
  7. aa.name=bb.name         --此处只是说明可以同时更新多个字段。  
  8. when not matched then    --不匹配关联条件,作插入处理。如果只是作更新,下面的语句可以省略。  
  9. insert values( bb.id, bb.name, bb.sex,bb.kecheng,bb.chengji);  

 --可以自行查询fzq1表。

涉及到多个表关联的例子,我们以三个表为例,只是作更新处理,不做插入处理。当然也可以只做插入处理

--将fzq1表中女生记录的成绩+1,没有直接去sex字段。而是fzq和fzq2关联。

Java代码  收藏代码
  1. merge into fzq1  aa     --fzq1表是需要更新的表  
  2. using (select fzq.id,fzq.chengji   
  3.        from fzq join fzq2  
  4.        on fzq.id=fzq2.id) bb  -- 数据集  
  5. on (aa.id=bb.id)        --关联条件  
  6. when matched then       --匹配关联条件,作更新处理  
  7. update set  
  8. aa.chengji=bb.chengji+1  

 --可以自行查询fzq1表。

不能做的事情

Java代码  收藏代码
  1. merge into fzq1  aa      
  2. using fzq bb             
  3. on (aa.id=bb.id)          
  4. when matched then         
  5. update set  
  6. aa.id=bb.id+1  

 系统提示:

ORA-38104: Columns referenced in the ON Clause cannot be updated: "AA"."ID"

我们不能更新on (aa.id=bb.id)关联条件中的字段

update fzq1 

set  id=(select id+1 from fzq where fzq.id=fzq1.id)

where id in

(select id from fzq)

--使用update就可以更新,如果有更好的方法,谢谢反馈!

分享到:
评论

相关推荐

    oracle merge into的使用

    标题:Oracle Merge Into 的使用 描述详解:Oracle Merge Into 是一个功能强大的SQL语句,它在Oracle数据库系统中被广泛用于处理数据同步、更新或插入操作。与传统的UPDATE和INSERT语句相比,Merge Into 提供了更为...

    Oracle merge into用法

    在Oracle数据库中,`MERGE INTO`语句是一种非常强大的工具,它允许用户根据源表中的数据更新目标表,同时也可以插入新记录。这一特性在处理大量数据时尤其有用,因为它能够在一个步骤中完成更新和插入操作,从而提高...

    Oracle中merge into的使用

    在Oracle数据库中,`MERGE INTO`语句是一种强大的数据操作工具,它允许你在一个步骤中执行更新(UPDATE)和插入(INSERT)操作,从而提高了数据处理的效率和灵活性。这个命令尤其适用于需要同步两个表的数据时,比如...

    浅谈Oracle数据库中Merge Into的用法.pdf

    Oracle 数据库中 Merge Into 的用法 在 Oracle 数据库中,Merge Into 语句是一种非常有用的功能,它主要用来合并 update 和 insert 语句,即用一个表中的数据来修 改或插入到另一个表中。Merge Into 语句的主要原则...

    oracle死锁原因解决办法

    ### Oracle死锁原因及解决办法 #### 一、Oracle死锁概述 在Oracle数据库系统中,死锁是一种常见的并发问题,它会导致多个事务之间互相等待对方释放资源而无法继续执行,最终导致整个系统的运行效率降低甚至停滞。...

    Mybatis批量foreach merge into的用法

    首先,需要使用Oracle 9i及其以后版本支持的merge into语句,该语句可以实现insertOrUpdate的功能。然后,使用Mybatis的动态SQL语法foreach循环插入,待插入的实体bean的List通过查询数据库dual形成表。foreach的 ...

    oracle merge 用法详解

    #### 一、Oracle Merge 命令介绍 自Oracle 9i版本开始,Oracle数据库引入了一个非常强大的SQL语句——`MERGE`命令。通过这个命令,用户可以在一个单一的SQL语句中完成对表的插入(`INSERT`)和更新(`UPDATE`)操作,极...

    Oracle MERGE INTO的用法示例介绍

    如果不使用Oracle提供的merge语法的话,可能先要上数据库select查询一下看是否存在,然后决定怎么操作,这样的话需要写更多的代码,同时性能也不好,要来回数据库两次.使用merge的话则可以一条SQL语句完成. 1)主要功能 ...

    oracle Merge 函数.doc

    "Oracle Merge 函数详解" Oracle Merge 函数是一种强大的数据操作语句,用于从一个表中选择一些数据更新或者插入到另一个表中。Merge 函数的使用方式有三种:只更新不插入、只插入不更新和既插入也更新。 Merge ...

    oracle中merge into用法及实例解析

    Oracle中的`MERGE INTO`语句是一种强大的工具,用于整合数据操作,如更新、插入和删除,基于两个数据源的匹配条件。这个语句在处理数据仓库、数据同步或者复杂业务逻辑时非常有用。让我们详细了解一下`MERGE INTO`的...

    使用BULK COLLECT, MERGE 语句提高sql执行效率

    详细介绍了使用 BULK COLLECT 进行批量操作 提高sql的执行效率 使用MERGE INTO USING 一条sql搞定 新增和修改 使用connect by 进行递归树查询

    Oracle_merge

    本文将详细介绍 Oracle 中 `MERGE` 关键字的使用方法,并结合实际示例来解析其工作原理。 #### 二、`MERGE` 语句的基本概念 在 Oracle 9i R2 版本之前,如果需要同时进行更新和插入操作,开发人员通常需要编写两条...

    oracle数据匹配merge into的实例详解

    Oracle的`MERGE INTO`语句是一种强大的工具,用于根据源数据更新或插入目标表的记录。这个SQL命令结合了`INSERT`, `UPDATE`和`DELETE`操作,使得在处理数据匹配和同步时更加高效。在给定的实例中,`MERGE INTO`被...

    Oracle merge合并更新函数实例详解

    Oracle的MERGE语句是一种强大的数据操作工具,它在Oracle9i版本中被引入,用于合并UPDATE和INSERT操作。在处理需要根据特定条件更新或插入数据的场景时,MERGE语句提供了高效的解决方案,尤其适合那些需要在单个SQL...

    oracle merge

    merge 详解 及实例 优点:  — 避免了分开更新  — 提高性能并易于使用  — 在数据仓库应用中十分有用  — 使用merge比传统的先判断再选择插入或更新快很多

    利用 sqluldr2导出数据 使用sqlldr导入数据 通过merge into 合并更新数据

    下面将详细阐述如何使用这两个工具以及如何通过`MERGE INTO`语句进行数据合并更新。 1. SQLULDR2导出数据: SQLULDR2是Oracle提供的一款数据导出工具,它能够快速地将数据库中的数据导出到文本文件或其他格式的...

Global site tag (gtag.js) - Google Analytics