zoukankan      html  css  js  c++  java
  • oracle merge into用法

    oracle merge into用法  

    2011-08-24 10:52:54|  分类: oracle|举报|字号 订阅

     
     
            在平时更新数据时,经常有这样一种更新,即将目标表中的数据与源表对比,如果存在记录,则根据源表中的值更新目标表中的数据,如果不存在的话,则新增入目标表中。我们当然可以使用两条语句来处理这类数据。但这其中有可能会出现异常。因此,Oracle在9i版本新增了MERGE语句,来合并UPDATE和INSERT语句。 该语句可以在同一语句中执行两步操作,可以减少执行多条insert 和update语句。merge是一个确定性的语句,即不会在同一条merge语句中去对同一条记录多次做修改操作。
         
      具体语法为: 
        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; 

    1.into 子句
    在into子句中指定所要修改或者插入数据的目标表

    2.using 子句
    在using子句中指定用来修改或者插入的数据源。数据源可以是表、视图或者一个子查询语句。

    3.on 子句
    在on子句中指定执行插入或者修改的满足条件。在目标表中符合条件的每一行,oracle用数据源中的相应数据修改这些行。对于不满足条件的那些行,oracle则插入数据源中相应数据。

    4.when matched | not matched
    用该子句通知oracle如何对满足或不满足条件的结果做出相应的操作。可以使用以下的两类子句。

    5.merge_update子句
    merge_update子句执行对目标表中的字段值修改。当在符合on子句条件的情况下执行。如果修改子句执行,则目标表上的修改触发器将被触发。
    限制:当修改一个视图时,不能指定一个default值

    6.merge_insert 子句
    merge_insert子句执行当不符合on子句条件时,往目标表中插入数据。

    下面列出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中也同样适用。

  • 相关阅读:
    BZOJ 3997: [TJOI2015]组合数学 [偏序关系 DP]
    [Sdoi2017]新生舞会 [01分数规划 二分图最大权匹配]
    [Sdoi2017]相关分析 [线段树]
    [Sdoi2017]硬币游戏 [高斯消元 KMP]
    [Sdoi2017]序列计数 [矩阵快速幂]
    [Sdoi2017]树点涂色 [lct 线段树]
    [Sdoi2017]数字表格 [莫比乌斯反演]
    BZOJ 3160: 万径人踪灭 [fft manacher]
    Rabbitmq常见测试
    MQ(消息队列)功能介绍
  • 原文地址:https://www.cnblogs.com/zuozongyao/p/4378700.html
Copyright © 2011-2022 走看看