`

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效率非常高。

 

 

自己做过的Demo

merge into masadw.tb_dw_ac_not_app_spt_old a
    using (select t.user_id,t.acct_item_id,t.receivable_fee,t.acct_cycle_id
             from masadw.tb_ac_acct_not_app_spt_old t) b
    on(a.user_id=b.user_id and a.acct_item_id=b.acct_item_id)
    when matched then update set
    a.receivable_fee = b.receivable_fee
    when not matched then insert
    (
     a.user_id,
     a.acct_item_id,
     a.receivable_fee,
     a.acct_cycle_id
    )
    values
    (
     b.user_id,
     b.acct_item_id,
     b.receivable_fee,
     b.acct_cycle_id
    );

分享到:
评论

相关推荐

    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比传统的先判断再选择插入或更新快很多

    oracle+11g+使用教程

    ### Oracle 11g 使用教程知识点详解 #### 一、Oracle 11g 概述 Oracle 11g 是 Oracle 公司推出的第 11 版本的数据库管理系统,它在 Oracle 10g 的基础上进行了多方面的改进与增强,提供了更强大的功能和更高的性能...

    ORACLE EBS 开发基础

    Mergeinto应用** - MERGE INTO语句用于合并两个表中的数据,可以替代复杂的INSERT和UPDATE语句。 **9. Truncatetable** - TRUNCATE TABLE命令用于快速清空表中的所有数据。 **10. 绑定变量与非绑定变量之比较** -...

    Oracle从入门到精通

    - **Oracle**:一款广泛使用的商业关系型数据库管理系统。 - **SQL**(Structured Query Language):用于管理和处理Oracle数据库中的数据的标准语言。 ##### 1.2 数据库安全 - **认证**:验证用户身份的过程。 - *...

    oracle学习资料

    ### Oracle学习资料知识点详解 #### 一、Oracle相关(基础+环境) **1.1 Oracle 10g的安装** - **Windows XP环境下图形化安装:** - 确保系统满足Oracle 10g的最低配置要求。 - 下载Oracle 10g安装包,通常为....

    02_Oracle_Royallin.pdf

    ### Oracle复习资料知识点详解 #### 一、Oracle 相关(基础+环境) **1.1 Windows XP 下 Oracle 10g 的安装** - **图形界面安装:** - 准备工作:确保Windows XP系统满足Oracle 10g的最低配置要求。 - 启动安装...

    My SQL知识大全

    ### MySQL基础知识及应用详解 #### 一、MySQL简介与历史沿革 MySQL是一款关系型数据库管理系统,由瑞典MySQL AB公司于1995年开发,2008年被Sun Microsystems收购,随后在2009年Sun Microsystems又被Oracle公司收购...

Global site tag (gtag.js) - Google Analytics