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. 這是什么情況???2. javascript - webpack編譯后的文件不生效,未編譯的文件生效3. thinkphp3 count()方法必須加上字段?4. mysql 5個left關鍵 然后再用搜索條件 幾千條數據就會卡,如何解決呢5. javascript - 關于input="file",重復選擇同一文件時不觸發change事件的問題6. python - 這句是什么錯誤?7. 輸入地址報以下截圖錯誤,怎么辦?8. mysql - SQL server 誤用delete 怎么恢復?9. 怎么php怎么通過數組顯示sql查詢結果呢,查詢結果有多條,如圖。我要forsearch里面echo10. python中return 語句與 分支語句連用問題
