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. PHP单例模式2. node.js - nvm怎么更新node的最新版本呀?3. html5 - 目前 公司App 嵌入H5页面 做个 手机支付功能 没有做过 所以 请求各位有经验的 给个思路4. dockerfile - [docker build image失败- npm install]5. Angular.js 无法设置Authorization头,该怎么解决?6. html5 - Vue绑定动态变量不可用7. docker不显示端口映射呢?8. Docker for Mac 创建的dnsmasq容器连不上/不工作的问题9. angular.js使用$resource服务把数据存入mongodb的问题。10. angular.js - angular内容过长展开收起效果