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. 为什么redis中incr一个“0” 会报错?2. javascript - 最近用echarts做统计图时遇到两个问题!!3. android - 优酷的安卓及苹果app还在使用flash技术吗?4. nginx - 关于vue项目部署到ngnix后出现的问题5. css内联样式的style6. python - 使用scrapy框架爬百度图片被墙7. java - 一个泛型标签问题8. javascript - 如何使用Canvas改变素材的颜色?9. java类中的成员成员变量赋值之后什么时候会被回收,有什么办法监听到某一个对象被回收吗10. css - input中transition 设置background-color过渡,chrome浏览器页面初始化渲染会有过度效果

网公网安备