SpringBoot+MyBatis實(shí)現(xiàn)動(dòng)態(tài)字段更新的三種方法
在Spring Boot和MyBatis中,實(shí)現(xiàn)動(dòng)態(tài)更新不固定字段的步驟如下:
方法一:使用MyBatis動(dòng)態(tài)SQL(適合字段允許為null的場(chǎng)景)
定義實(shí)體類
包含所有可能被更新的字段。
Mapper接口
定義更新方法,參數(shù)為實(shí)體對(duì)象:
void updateUserSelective(User user);
XML映射文件
使用<set>
和<if>
動(dòng)態(tài)生成SQL:
<update id="updateUserSelective" parameterType="User"> UPDATE user <set> <if test="name != null">name = #{name},</if> <if test="age != null">age = #{age},</if> <if test="address != null">address = #{address},</if> <if test="phone != null">phone = #{phone},</if> </set> WHERE id = #{id} </update>
注意:此方法無法將字段更新為null
,因?yàn)閰?shù)為null
時(shí)條件不成立。
方法二:使用Map和字段過濾(支持字段更新為null)
Service層過濾字段
在Service中定義允許更新的字段,并過濾請(qǐng)求參數(shù):
public void updateUser(Long id, Map<String, Object> updates) { Set<String> allowedFields = Set.of("name", "age", "address", "phone"); updates.keySet().retainAll(allowedFields); // 過濾非法字段 userMapper.updateUserSelective(id, updates); }
Mapper接口
使用Map接收動(dòng)態(tài)字段:
void updateUserSelective(@Param("id") Long id, @Param("updates") Map<String, Object> updates);
XML映射文件
動(dòng)態(tài)生成更新語句:
<update id="updateUserSelective"> UPDATE user <set> <foreach collection="updates" index="key" item="value" separator=","> ${key} = #{value} </foreach> </set> WHERE id = #{id} </update>
注意:使用${key}
存在SQL注入風(fēng)險(xiǎn),需在Service層嚴(yán)格過濾字段名。
方法三:使用@UpdateProvider(靈活且安全)
定義SQL提供類
動(dòng)態(tài)構(gòu)建安全SQL:
public class UserSqlProvider { public String updateSelective(Map<String, Object> params) { Long id = (Long) params.get("id"); Map<String, Object> updates = (Map<String, Object>) params.get("updates"); Set<String> allowedFields = Set.of("name", "age", "address", "phone"); StringBuilder sql = new StringBuilder("UPDATE user SET "); allowedFields.forEach(field -> { if (updates.containsKey(field)) { sql.append(field).append(" = #{updates.").append(field).append("}, "); } }); sql.setLength(sql.length() - 2); // 移除末尾逗號(hào) sql.append(" WHERE id = #{id}"); return sql.toString(); } }
Mapper接口
使用@UpdateProvider注解:
@UpdateProvider(type = UserSqlProvider.class, method = "updateSelective") void updateUserSelective(@Param("id") Long id, @Param("updates") Map<String, Object> updates);
優(yōu)點(diǎn):避免SQL注入,動(dòng)態(tài)生成安全語句。
總結(jié)
方法一適合簡單場(chǎng)景,字段無需設(shè)置為
null
。方法二靈活,需嚴(yán)格過濾字段。
方法三推薦用于生產(chǎn)環(huán)境,安全且維護(hù)性強(qiáng)。
根據(jù)需求選擇合適方案,確保字段更新的靈活性和安全性。
到此這篇關(guān)于SpringBoot+MyBatis實(shí)現(xiàn)動(dòng)態(tài)字段更新的三種方法的文章就介紹到這了,更多相關(guān)SpringBoot MyBatis字段更新內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
springboot整合持久層的方法實(shí)現(xiàn)
本文主要介紹了springboot整合持久層的方法實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-09-09Spring Boot 深入分析AutoConfigurationImportFilter自動(dòng)化條件
這篇文章主要分析了Spring Boot AutoConfigurationImportFilter自動(dòng)化條件配置源碼,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)吧2022-07-07SpringBoot實(shí)現(xiàn)初始化的三種策略模式
本文主要介紹了SpringBoot實(shí)現(xiàn)初始化的三種策略模式,包括默認(rèn)初始化策略、懶加載初始化策略和自定義初始化策略,具有一定的參考價(jià)值,感興趣的可以了解一下2024-12-12springmvc圖片上傳及json數(shù)據(jù)轉(zhuǎn)換過程詳解
這篇文章主要介紹了springmvc圖片上傳及json數(shù)據(jù)轉(zhuǎn)換過程詳解,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-10-10Springboot使用maven打包指定mainClass問題
這篇文章主要介紹了Springboot使用maven打包指定mainClass問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-04-04Java和SQL實(shí)現(xiàn)取兩個(gè)字符間的值
這篇文章主要介紹了Java和SQL實(shí)現(xiàn)取兩個(gè)字符間的值操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-06-06maven工程打包引入本地jar包的實(shí)現(xiàn)
我們需要將jar包發(fā)布到一些指定的第三方Maven倉庫,本文主要介紹了maven工程打包引入本地jar包的實(shí)現(xiàn),具有一定的參考價(jià)值,感興趣的可以了解一下2024-02-02