zoukankan      html  css  js  c++  java
  • (转)MERGE语法详解

    merge语法是根据源表对目标表进行匹配查询,匹配成功时更新,不成功时插入。

    其基本语法规则是

    merge into 目标表 a

    using 源表 b

    on(a.条件字段1=b.条件字段1 and a.条件字段2=b.条件字段2 ……)  

    when matched then update set a.更新字段=b.字段

    when  not macthed then insert into a(字段1,字段2……)values(值1,值2……)

    变种写法①,只更新:

    merge into 目标表 a

    using 源表 b

    on(a.条件字段1=b.条件字段1 and a.条件字段2=b.条件字段2 ……)  

    when matched then update set a.更新字段=b.字段,a.更新字段2=b.字段2……

    变种写法②,只插入:

    merge into 目标表 a

    using 源表 b

    on(a.条件字段1=b.条件字段1 and a.条件字段2=b.条件字段2 ……)  

    when  not macthed then insert into a(字段1,字段2……)values(值1,值2……)

    注:条件字段不可更新

    对于Oracle来说,merge是9i新增的语法,在10g进行了一些增强,如下:

    测试环境:Oracle Database 11g Enterprise Edition Release 11.2.0.1.0

    ①条件操作:

    merge into 目标表 a

    using 源表 b

    on(a.条件字段1=b.条件字段1 and a.条件字段2=b.条件字段2 ……)  

    when matched then update set a.更新字段=b.字段  where 限制条件

    when  not macthed then insert into a(字段1,字段2……)values(值1,值2……) where 限制条件

    举例:

    merge into test_merge a
    using test b
    on(a.no=b.no)
    when matched then update set a.no2=b.no2 where a.no<>1
    when not matched then insert values(b.no,b.no2)  where a.no<>100

    当然也支持变种①②的写法

    ②删除操作

    merge into 目标表 a

    using 源表 b

    on(a.条件字段1=b.条件字段1 and a.条件字段2=b.条件字段2 ……)  

    when matched then update set a.更新字段=b.字段

    delete where b.字段=xxx

    举例:

    merge into test_merge a
    using test b
    on(a.no=b.no)
    when matched then update set a.no2=b.no2 where a.no<>1
    delete 
    where b.no=14

    备注:删除动作针对的也是目标表,并且必须在语句最后

    基本上merge的用法就是以上这些,建议平常可以多用,比单独的update+insert的方式效率要更高,尤其是on条件下有唯一索引的时候,效率更高

  • 相关阅读:
    Vue路由机制
    谷歌浏览器打不开应用商店的解决方法
    Vue报错——Component template should contain exactly one root element. If you are using vif on multiple elements, use velseif to chain them instead.
    Vue.js学习之——安装
    Vue使用axios无法读取data的解决办法
    关于localstorage存储JSON对象的问题
    2013年整体计划
    个人喜欢的警语收集
    Linux防火墙的关闭和开启
    Flex修改title 转载
  • 原文地址:https://www.cnblogs.com/toowang/p/9105851.html
Copyright © 2011-2022 走看看