mybatis 使用merge into


前一篇博客,oracle的merge into语法 : oracle merge into语法

mybatis 使用merge into,跟一般的update写法相同:

<update id="mergeinfo">
        merge into user_type a
        using ( select #{name} as name, #{type} as type from dual ) b
        on (a.type = b.type)
        when not matched then
        insert  (type,name) values(#{type},#{name})
        when matched then
        update set name = #{name} where type = #{type}
    </update>

 

传入字段 name、type,使用 “select #{name} as name, #{type} as type from dual”,构建一个子查询建别名 “b”,

目标表“a” 的type字段,与子查询表“b”的type字段比较:

  如果不匹配:

    执行 :“insert (type,name) values(#{type},#{name})”

  如果匹配:

    执行:“update set name = #{name} where type = #{type}”

主要on 后面的括弧不能省

 

测试代码:

  

@Test
    public void testmergeinfo(){
        map.put("type", "t");
        map.put("name", "venn");
        int a = sqlSession.update(“mergeinfo”,map); 
     sqlSession.commit();
     System.out.println(a); }

 

输出插入或更新的记录条数。

 


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM