您的位置:首页技术文章
文章详情页

java - mybatis mysql 如何实现upsert功能?

【字号: 日期:2024-02-05 08:12:27浏览:28作者:猪猪

问题描述

1、数据不存在insert;2、数据存在update;3、表中有一个唯一约束;并根据该约束执行具体的插入或者修改操作。

————————————————————————————

insert into T_name (uid, app_id,createTime,modifyTime) values(111, 1000000,’2017-03-07 10:19:12’,’2017-03-07 10:19:12’) on duplicate key update uid=111, app_id=1000000, createTime=’2017-03-07 10:19:12’,modifyTime=’2017-05-07 10:19:12’

如何把上边的sql,用mybatis改写?

问题解答

回答1:

<insert parameterType='Model'> insert into T_name(uid, name, age, balance) values (100,'yangyang', 23, 100000000) on duplicate key update balance=balance + 100</insert>

以上代码,自己测试可以的。

回答2:

<insert parameterType='Model'>

insert into T_name (uid, name, age, balance) values (#{uid,jdbcType=VARCHAR},#{name}, 23, 100000000)on duplicate key update balance=balance + 100

</insert>

my mybatis 中 使用#{} 获取vo属性值

标签: java
相关文章: