Java Mybatis针对于Oracle表的插入更新操作merge into tablename using

近期公司产品提出需求,表数据根据主键判断插入或更新,有则更新无则插入,类似于hibernate的saveorupdate方法。对于Mybatis来说Mapping.xml怎么写呢,针对于oracle数据库的merge into tablename using语法,代码如下:

<insert id="insertList" parameterType="java.util.List">
    MERGE INTO SE_BMS T1
    USING
    (
     <foreach collection="list" item="item" index="index" separator="union" > 
         SELECT 
             #{item.Student_id,jdbcType=VARCHAR} Student_id,
             #{item.Student_name,jdbcType=VARCHAR}Student_name,
             #{item.Student_age,jdbcType=VARCHAR} Student_age,
             #{item.Student_sex,jdbcType=INTEGER} Student_sex
             FROM DUAL
     </foreach>
    ) T
    ON
    (
      T1.Student_id = T.Student_id 
    )
    WHEN MATCHED THEN

           UPDATE SET 
             Student_name= T.Student_name,
             Student_age= T.Student_age,
             Student_sex= T.Student_sex

    WHEN NOT MATCHED THEN
            INSERT(Student_id,Student_name,Student_age,Student_sex)
            VALUES(
             T.Student_id,
             T.Student_name,
             T.Student_age,
             T.Student_sex
            )

</insert>

根据T1.Student_id = T.Student_id去判断唯一性。有则执行update,没有则执行WHEN NOT MATCHED THEN后面的插入语句。

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值