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. javascript - 按鈕鏈接到另一個網址 怎么通過百度統計計算按鈕的點擊數量2. sql語句 - 如何在mysql中批量添加用戶?3. mysql 可以從 TCP 連接但是不能從 socket 鏈接4. mysql - 數據庫建字段,默認值空和empty string有什么區別 1105. 怎么php怎么通過數組顯示sql查詢結果呢,查詢結果有多條,如圖。6. 請教一個mysql去重取最新記錄7. 事務 - mysql共享鎖lock in share mode的實際使用場景8. java - jdbc如何返回自動定義的bean9. mysql - JAVA怎么實現一個DAO同時實現查詢兩個實體類的結果集10. mysql 非主鍵做范圍查找實現原理的一點困惑
