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. golang - 用IDE看docker源碼時的小問題2. docker不顯示端口映射呢?3. docker安裝后出現Cannot connect to the Docker daemon.4. 在windows下安裝docker Toolbox 啟動Docker Quickstart Terminal 失敗!5. docker-compose中volumes的問題6. 我在centos容器里安裝docker,也就是在容器里安裝容器,報錯了?7. docker容器呢SSH為什么連不通呢?8. docker內創建jenkins訪問另一個容器下的服務器問題9. javascript - 最近用echarts做統計圖時遇到兩個問題!!10. mac里的docker如何命令行開啟呢?

網公網安備