Java Mybatis批量修改封裝詳解
重點重點重點,不然會報錯
連接數據庫url后面加個參數
allowMultiQueries=true
用習慣了 insertList 怎么能沒有 updateList呢
就兩個類 直接上代碼
package com.lancabbage.gorgeous.utils.mybatis; import org.apache.ibatis.mapping.MappedStatement; import tk.mybatis.mapper.entity.EntityColumn; import tk.mybatis.mapper.mapperhelper.EntityHelper; import tk.mybatis.mapper.mapperhelper.MapperHelper; import tk.mybatis.mapper.mapperhelper.MapperTemplate; import tk.mybatis.mapper.mapperhelper.SqlHelper; import java.util.Set; import static tk.mybatis.mapper.mapperhelper.SqlHelper.whereVersion; /** * ListUpdateProvider實現(xiàn)類,批量修改方法實現(xiàn)類 * * @author lanyanhua */ public class ListUpdateProvider extends MapperTemplate { public ListUpdateProvider(Class<?> mapperClass, MapperHelper mapperHelper) { super(mapperClass, mapperHelper); } // /** // * 通過主鍵更新全部字段 // * // * @param ms // */ // public String updateByPrimaryKey(MappedStatement ms) { // Class<?> entityClass = getEntityClass(ms); // StringBuilder sql = new StringBuilder(); // sql.append(SqlHelper.updateTable(entityClass, tableName(entityClass))); // sql.append(SqlHelper.updateSetColumns(entityClass, null, false, false)); // sql.append(SqlHelper.wherePKColumns(entityClass, true)); // return sql.toString(); // } /** * 通過主鍵更新不為null的字段 * * @param ms * @return */ public String updateByPrimaryKeySelectiveList(MappedStatement ms) { Class<?> entityClass = getEntityClass(ms); StringBuilder sql = new StringBuilder(); sql.append("<foreach collection=\"list\" item=\"record\" >"); //set sql.append(SqlHelper.updateTable(entityClass, tableName(entityClass))); sql.append(SqlHelper.updateSetColumns(entityClass, "record", true, isNotEmpty())); //where sql.append("<where>"); Set<EntityColumn> columnSet = EntityHelper.getPKColumns(entityClass); //當某個列有主鍵策略時,不需要考慮他的屬性是否為空,因為如果為空,一定會根據主鍵策略給他生成一個值 for (EntityColumn column : columnSet) { sql.append(" AND ").append(column.getColumnEqualsHolder("record")); } sql.append(whereVersion(entityClass)); sql.append("</where>"); sql.append(" ;\n"); sql.append("</foreach>"); return sql.toString(); } }
package com.lancabbage.gorgeous.utils.mybatis; import org.apache.ibatis.annotations.UpdateProvider; import tk.mybatis.mapper.annotation.RegisterMapper; import java.util.List; /** * 通用Mapper接口,更新 * * @param <T> 不能為空 * @author lanyanhua */ @RegisterMapper public interface ListUpdateByPrimaryKeySelectiveMapper<T> { /** * 根據主鍵更新屬性不為null的值 * * @param record * @return */ @UpdateProvider(type = ListUpdateProvider.class, method = "dynamicSQL") int updateByPrimaryKeySelectiveList(List<T> record); }
我是使用的是Tk.mybatis。代碼是復制的原來的updateByPrimaryKeySelective的代碼進行的微調
保證最終的結構類似這種就ok
<foreach collection="list" item="record" separator=";"> UPDATE project <set>id = id, <if test="record.name != null">name = #{record.name},</if> <if test="record.remotePath != null">remote_path = #{record.remotePath},</if> <if test="record.createTime != null">create_time = #{record.createTime},</if> <if test="record.isShow != null">is_show = #{record.isShow},</if> <if test="record.displayOrder != null">display_order = #{record.displayOrder},</if> </set> <where>AND id = #{record.id}</where> </foreach>
使用 就和其他的一樣 在你的Mapper類上繼承這個類ListUpdateByPrimaryKeySelectiveMapper就好了
public interface BaseMapper<T> extends Mapper<T>, MySqlMapper<T>, ListUpdateByPrimaryKeySelectiveMapper<T> { }
總結
本篇文章就到這里了,希望能夠給你帶來幫助,也希望您能夠多多關注腳本之家的更多內容!
相關文章
Eureka源碼閱讀Client啟動入口注冊續(xù)約及定時任務
這篇文章主要為大家介紹了Eureka源碼閱讀Client啟動入口注冊續(xù)約及定時任務示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-10-10Spring?main方法中如何調用Dao層和Service層的方法
這篇文章主要介紹了Spring?main方法中調用Dao層和Service層的方法,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-12-12最簡單的MyBatis Plus的多表聯(lián)接、分頁查詢實現(xiàn)方法
這篇文章主要介紹了最簡單的MyBatis Plus的多表聯(lián)接、分頁查詢實現(xiàn)方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-11-11idea?maven依賴引入失效無法正常導入依賴問題的解決方法
有時候idea導入一個新項目,或者pom文件修改(新增)了依賴,pom文件和代碼會報紅,提示依賴包不存在,下面這篇文章主要給大家介紹了關于idea?maven依賴引入失效無法正常導入依賴問題的解決方法,需要的朋友可以參考下2023-04-04java使用Apache工具集實現(xiàn)ftp文件傳輸代碼詳解
這篇文章主要介紹了java使用Apache工具集實現(xiàn)ftp文件傳輸代碼詳解,分享了詳細連接ftp server和上傳文件,下載文件的代碼,以及結果展示,具有一定借鑒價值,需要的朋友可以參考下。2017-12-12SpringBoot實現(xiàn)ORM操作MySQL的幾種方法
本文主要介紹了SpringBoot實現(xiàn)ORM操作MySQL的幾種方法,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-02-02SpringBoot統(tǒng)一處理功能實現(xiàn)的全過程
最近在做項目時需要對異常進行全局統(tǒng)一處理,主要是一些分類入庫以及記錄日志等,下面這篇文章主要給大家介紹了關于SpringBoot統(tǒng)一功能處理實現(xiàn)的相關資料,文中通過圖文以及實例代碼介紹的非常詳細,需要的朋友可以參考下2023-03-03