java - mybatis mysql 如何实现upsert功能?
问题描述
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属性值
相关文章:
1. javascript - 移动端H5页面禁止缩放了,在浏览器上仍然可以缩放2. javascript - JS设置Video视频对象的currentTime时出现了问题,IE,Edge,火狐,都可以设置,反而chrom却...3. python的bs4如何筛选出h1标签中的内容4. docker-compose 为何找不到配置文件?5. 前端 - css3 3d效果问题6. docker gitlab 如何git clone?7. android - 安卓做前端,PHP做后台服务器 有什么需要注意的?8. java - spring-data Jpa 不需要执行save 语句,Set字段就可以自动执行保存的方法?求解9. angular.js - 通过数据中children的个数自动生成能点击展开的div10. css - 使用blur()滤镜为什么有透明的效果
