`
beliveAda
  • 浏览: 112593 次
  • 性别: Icon_minigender_2
  • 来自: 西安
社区版块
存档分类
最新评论

使用merge语句更新数据库中的记录

 
阅读更多
    在平时更新数据时,经常有这样一种更新,即将表中的数据与源表对比,如果存在记录,则根据源表中的值更新目标表中的数据,如果不存在的话,则新增入目标表中。我们当然可以使用两条语句来处理这类数据。但这其中有可能会出现异常。因此,Oracle在9i版本新增了MERGE语句,来合并UPDATE和INSERT语句。

    通过MERGE语句,根据一张表或子查询的连接条件对另外一张表进行查询,连接条件匹配上的进行UPDATE,无法匹配的执行INSERT。这个语法仅需要一次全表扫描就完成了全部工作,执行效率要高于INSERT+UPDATE。

    具体语法为:
    MERGE [hint] 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的基本用法 (此处目标表和源表表结构相同)
  1) matched 和not matched 同时使用
   merge into 目标表  a
     using 源表 b on (关联条件 a.字段1 = b.字段1)
   when MATCHED then
        update set a.字段2=b.字段2,......
   when NOT MATCHED then
        insert(a.字段2,a.字段3)
        values(b.字段2,b.字段3);
  2) 只有not matched clause,也就是只插入不更新
   merge into 目标表 a
     using  源表b on (关联条件 a.字段1 = b.字段1)  
   when NOT MATCHED then
       insert(a.字段2,a.字段3)
        values(b.字段2,b.字段3);

  3) 只有matched clause, 也就是只更新不插入
   merge into 目标表  a
     using 源表 b on (关联条件 a.字段1 = b.字段1)
   when MATCHED then
        update set a.字段2=b.字段2,......
   
另外,merge命令的update部分可以包含一个delete子句。delete子句(有其自己的where子句)可以删除目标表中被merge更新的行。delete...where子句可以计算更新值,而不是目标表中的初始值。如果目标表中的行符合delete...where条件但不在merge所作用(就如on条件所定义的)的行集范围内,就不会删除。
    具体语法为:
       using 源表 b on (关联条件 a.字段1 = b.字段1)
   when MATCHED then
        update set a.字段2=b.字段2,......
        delete where (a.字段5=b.字段5) ;

   注意:此处的源表可以不仅仅是一张表,也可以是查询出来的结果集。此命令在db2中也同样适用。



 
分享到:
评论

相关推荐

    DB2 merge语句使用教程

    DB2 Merge 语句是数据库管理系统 DB2 中用于合并数据的一种高级操作,它结合了插入、更新和删除的功能,能够高效地处理多个数据源之间的数据同步。本教程将详细介绍 DB2 Merge 语句的使用方法。 首先,让我们通过一...

    Mybatis批量foreach merge into的用法

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

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

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

    Merge-Sql.zip

    本文将深入探讨MERGE语句的使用,以及在不支持MERGE的数据库环境中可能采取的替代策略。 首先,让我们理解什么是MERGE语句。在SQL标准中,MERGE是一种DML(数据操纵语言)操作,它结合了INSERT、UPDATE和DELETE的...

    merge用法详解(实例详解)

    `MERGE`语句是数据库操作中一种非常强大的工具,它结合了`INSERT`, `UPDATE`, 和 `DELETE`的功能,可以一次性处理数据的插入、更新和删除操作,尤其是在数据同步或数据仓库场景中非常实用。本文将详细解释`MERGE`...

    Oracle中merge into的使用

    通过`MERGE INTO`,我们可以更加灵活地管理数据库中的数据,无论是更新已有记录,还是插入新记录,甚至删除不符合条件的记录,都可以在一个SQL语句中完成,极大地简化了编程逻辑,提高了代码的可读性和执行效率。...

    MySQL中实现插入或更新操作(类似Oracle的merge语句)

    如果需要在MySQL中实现记录不存在则insert,不存在则update操作。可以使用以下语句: 更新一个字段: INSERT INTO tbl (columnA,columnB,columnC) VALUES (1,2,3) ON DUPLICATE KEY UPDATE columnA=IF(columnB>0,...

    Oracle merge into用法

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

    Oracle_merge

    此外,`MERGE` 语句还可以结合 `DELETE` 功能,允许在同一步骤中更新现有记录的同时删除旧记录。 #### 五、示例分析 以下是一个具体的例子,通过该示例我们可以更深入地理解 `MERGE` 语句的工作机制。 1. **创建...

    oracle merge into的使用

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

    Merge into的使用详解

    总结来说,`MERGE INTO`语句是数据库管理中的一个重要工具,尤其是在处理数据同步和更新时。熟练掌握`MERGE INTO`的用法,能够有效地提升数据处理的效率和准确性。通过实例,我们可以看到它如何根据不同的匹配情况...

    oracle Merge 函数.doc

    "Oracle Merge 函数详解" Oracle Merge 函数是一种强大...这时,如果执行 Merge 语句,会抛出错误:ORA-30926: 无法在源表中唯一地标识记录 因此,在使用 Merge 函数时,需要小心地处理关联的值,以避免错误的发生。

    读取Excel表中的数据与数据库中的比对

    一旦连接建立,我们就可以从数据库中提取数据,通常会用到`SELECT`语句。然后,将查询结果转换为DataFrame以便与Excel数据进行比对: ```python # 执行SQL查询 cursor = conn.cursor() sql_query = "SELECT * FROM ...

    Oracle数据库---存储过程实例

    根据提供的文件信息,我们可以深入探讨Oracle数据库中的存储过程以及如何使用MERGE语句。尽管描述部分似乎包含了无意义的信息,但我们将重点放在标题、标签以及部分内容上,从中提炼出有价值的知识点。 ### Oracle...

    merge用法详解

    `MERGE`语句在Oracle数据库中是一种非常实用的DML操作,它结合了`INSERT`、`UPDATE`和`DELETE`的功能,使得在处理数据时更加高效且简洁。这个语句自Oracle 9i版本开始引入,主要用于解决在两个数据源之间进行有条件...

    merge的用法

    在数据库操作中,`MERGE`语句是一种非常强大的工具,它结合了`UPDATE`和`INSERT`的功能,允许我们根据源表中的数据更新目标表中的记录,如果源表中的记录在目标表中不存在,则可以插入新记录。此功能非常适合于数据...

    Hibernate save persist merge探究

    值得注意的是,如果对象已经存在数据库中并且具有非空的ID,再调用save()会导致重复记录,因此需谨慎使用。 二、persist()方法 自Hibernate 3.0引入,persist()成为了推荐的持久化方式。它的行为与save()类似,也是...

    oracle死锁原因解决办法

    当Oracle数据库检测到死锁时,会在警报日志文件(alert.log)中记录相关信息。这些信息对于分析死锁的原因至关重要。例如,在提供的部分内容中,可以看到以下日志条目: ``` Mon Aug 07 09:14:42 2007 ORA-000060: ...

Global site tag (gtag.js) - Google Analytics