zoukankan      html  css  js  c++  java
  • oracle merge into 的用法详解+实例

    转自:http://www.cnblogs.com/xy6521/articles/1310177.html

    oracle merge into 的用法详解+实例

    作用:merge into 解决用B表跟新A表数据,如果A表中没有,则把B表的数据插入A表;

    语法:

    MERGE INTO [your table-name] [rename your table here]

    USING ( [write your query here] )[rename your query-sql and using just like a table]

    ON ([conditional expression here] AND [...]...)

    WHEN MATHED THEN [here you can execute some update sql or something else ]

    WHEN NOT MATHED THEN [execute something else here ! ]

    -------------------------------------实例-----------------------------------------------------------------

    merge into tfa_alarm_act_nms a
    using (select FP0,FP1,FP2,FP3,REDEFINE_SEVERITY
    from tfa_alarm_status) b
    on (a.fp0=b.fp0 and a.fp1=b.fp1 and a.fp2=b.fp2 and a.fp3=b.fp3)
    when matched then update set a.redefine_severity=b.redefine_severity
    when not matched then insert (a.fp0,a.fp1,a.fp2,a.fp3,a.org_severity,a.redefine_severity,a.event_time
    ,a.int_id)
    values (b.fp0,b.fp1,b.fp2,b.fp3,b.REDEFINE_SEVERITY,b.redefine_severity,sysdate,7777778);

    作用:利用表 tfa_alarm_status跟新表tfa_alarm_act_nms 的b.redefine_severity条件是a.fp0=b.fp0 and a.fp1=b.fp1 and a.fp2=b.fp2 and a.fp3=b.fp3,如果tfa_alarm_act_nms表中没有该条件的数据就插入。

    如果你的数据量很大,此sql效率非常高。

  • 相关阅读:
    【HDOJ】1558 Segment set
    【HDOJ】2395 Alarm Clock
    【HDOJ】4278 Faulty Odomete
    【HDOJ】2571 命运
    【HDOJ】2150 Pipe
    【HDOJ】1277 全文检索
    【HDOJ】1134 Game of Connections
    【HDOJ】5131 Song Jiang's rank list
    【HDOJ】2772 Matchsticks
    【HDOJ】2577 How to Type
  • 原文地址:https://www.cnblogs.com/zerocc/p/2137172.html
Copyright © 2011-2022 走看看