`

oracle merge 更新或插入数据

 
阅读更多
主要功能

提供有条件地更新和插入数据到数据库表中
如果该行存在,执行一个UPDATE操作,如果是一个新行,执行INSERT操作
— 避免了分开更新
— 提高性能并易于使用
— 在数据仓库应用中十分有用

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; 


MERGE例子

MERGE INTO copy_emp c    
USING employees e    
ON (c.employee_id=e.employee_id)    
WHEN MATCHED THEN   
UPDATE SET   
c.first_name=e.first_name,    
c.last_name=e.last_name,    
c.department_id=e.department_id    
WHEN NOT MATCHED THEN   
INSERT VALUES(e.employee_id,e.first_name,e.last_name,    
e.email,e.phone_number,e.hire_date,e.job_id,    
e.salary,e.commission_pct,e.manager_id,    
e.departmetn_id);  


注意:on子句的使用的字段不能够用于update,即Oracle不允许更新用于连接的列。

MERGE INTO MN A 
    USING MM B 
    ON(A.ID=B.ID) 
    WHEN MATCHED THEN 
    UPDATE SET A.NAME = B.NAME 
    WHEN NOT MATCHED THEN 
    INSERT VALUES(B.ID, B.NAME); 
ON(A.ID=B.ID) 


MERGE INTO TEST T USING TEST1 
ON T1.NAME = T.NAME
WHEN NOT MATCHED THEN
  INSERT
    (T.ID)
   values(
     sys_guid()
   );
分享到:
评论
发表评论

文章已被作者锁定,不允许评论。

相关推荐

    oracle使用 merge 更新或插入数据(总结)

    oracle使用 merge 更新或插入数据(总结)

    oracle使用 merge

    oracle使用 merge 更新或插入数据(总结@新

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

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

    Oracle_merge

    在Oracle 9i R2版中引入的MERGE语句通常被称作“更新插入”(upsert),因为使用MERGE可以在同一个步骤中更新(update)并插入(insert)数据行。。。。。。

    oracle merge

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

    Oracle MERGE INTO的用法示例介绍

    1)主要功能 提供有条件地更新和插入数据到数据库表中 如果该行存在,执行一个UPDATE操作,如果是一个新行,执行INSERT操作 — 避免了分开更新 — 提高性能并易于使用 — 在数据仓库应用中十分有用 2)MERGE语句的...

    merge_row_count:一个简单的实用程序,允许对由 Oracle 中的合并操作插入更新删除的行进行计数

    一个简单的实用程序 PL/SQL 包,允许对 Oracle 中的合并操作插入/更新/删除的行进行计数。 包的需要 Oracle不提供获取行数的功能。 插入 更新 已删除 使用 MERGE 操作完成所有操作时。 这个简单的实用程序是为了...

    oracle中merge into用法及实例解析

    作用:判断B表和A表是否满足ON中条件,如果满足则用B表去更新A表,如果不满足,则将B表数据插入A表但是有很多可选项,如下: 1.正常模式 2.只update或者只insert 3.带条件的update或带条件的insert 4.

    Oracle SQL高级编程(资深Oracle专家力作,OakTable团队推荐)--随书源代码

    9.4 返回更新后的行 232 9.5 求解顺序 233 9.5.1 行求解顺序 233 9.5.2 规则求解顺序 235 9.6 聚合 237 9.7 迭代 237 9.7.1 一个例子 238 9.7.2 PRESENTV与空值 239 9.8 查找表 240 9.9 空值 242 9.10 ...

    基于Oracle数据库的几种常见SQL优化策略.pdf

    通过 MERGE 命令,根据一张表或子查询的连接条件对数据进行合并、更新和插入操作,可以提高数据库的处理性能和查询效率。 本文档对基于Oracle数据库的几种常见SQL优化策略进行了讨论,旨在提高数据库的处理性能和...

    Oracle SQL高级编程

    2.12 执行计划并取得数据行 50 2.13 SQL执行——总览 52 2.14 小结 53 第3章 访问和联结方法 55 第4章 SQL是关于集合的 95 第5章 关于问题 116 第6章 SQL执行计划 137 第7章 高级分组 170 第8章 分析函数 197 第9章...

    达梦数据库sql语言使用手册

    达梦数据库sql语言手册,达梦数据库是国产数据库里最好使用的,可以跟oracle数据无缝替换的

    oracle学习经典教程

    1.3.2.1 插入: Insert with a subquery method ...........................46 1.3.2.1.1 Oracle 11g 的Interval................46 1.3.2.1.2 Oracle 10g 版本........................47 1.3.2.2 交换...

    oracle从入门到精通

    从多表中显示数据: .......................................................................................................25 1.8、用字函数产生的总计 ..................................................

    一个oracle指令的好网站

    * INSERT:用于插入数据的语句 * UPDATE:用于更新数据的语句 * MERGE:用于合并数据的语句 * EXPLAIN PLAN:用于解释执行计划的语句 * EXECUTE IMMEDIATE:用于执行立即执行的语句 * EXECUTE:用于执行 PL/SQL 块的...

    Oracle事例

    sql> alter index xay_id allocate extent(size 200k datafile \'c:/oracle/index.dbf\'); <8>.alter index xay_id deallocate unused; 、查看索引 SQL>select index_name,index_type,table_name from user...

    TianleSoftware Oracle中文学习手册

    1.2.1.6.4 比较不匹配的数据类型 ........................................................................ 1.2.1.7 查询索引...................................................................................

    Oracle从入门到精通

    7. tablespace 表空间:一个或多个数据文件的逻辑组成。 ..... 8. redo log file 重做日志文件............................. 9. control file 控制文件 ................................. 10. parameter file 初始...

Global site tag (gtag.js) - Google Analytics