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. android - 京东移动端网页和其app加载的url所做的呈现不应该是完全一样的吗?2. 关docker hub上有些镜像的tag被标记““This image has vulnerabilities””3. javascript - 在vue-cli引入vux后 使用报错4. python - 在sqlalchemy中获取刚插入的数据id?5. css3 - 这个效果用 CSS 可以实现吗?border-image6. 站点内容复制额外增加的版权申明,真的很反人类。试问产品自己在用这个站点吗?7. CSS3 flex 如何让高度不等的同排等高?8. javascript - 奇怪的Symbol的问题9. vue.js - vue 打包后 nginx 服务端API请求跨域问题无法解决。10. javamail发送邮件是否跟所在的网络环境有关?

网公网安备