欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

SpringBoot+MyBatis實現(xiàn)動態(tài)字段更新的三種方法

 更新時間:2025年04月25日 09:30:48   作者:BillKu  
字段更新是指在數(shù)據(jù)庫表中修改特定列的值的操作,這種操作可以通過多種方式進行,具體取決于業(yè)務需求和技術環(huán)境,本文給大家介紹了在Spring Boot和MyBatis中,實現(xiàn)動態(tài)更新不固定字段的三種方法,需要的朋友可以參考下

在Spring Boot和MyBatis中,實現(xiàn)動態(tài)更新不固定字段的步驟如下:

方法一:使用MyBatis動態(tài)SQL(適合字段允許為null的場景)

定義實體類

包含所有可能被更新的字段。

Mapper接口

定義更新方法,參數(shù)為實體對象:

void updateUserSelective(User user);

XML映射文件

使用<set><if>動態(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,因為參數(shù)為null時條件不成立。

方法二:使用Map和字段過濾(支持字段更新為null)

Service層過濾字段

在Service中定義允許更新的字段,并過濾請求參數(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接收動態(tài)字段:

void updateUserSelective(@Param("id") Long id, @Param("updates") Map<String, Object> updates);

XML映射文件

動態(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注入風險,需在Service層嚴格過濾字段名。

方法三:使用@UpdateProvider(靈活且安全)

定義SQL提供類

動態(tài)構建安全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); // 移除末尾逗號
        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)點:避免SQL注入,動態(tài)生成安全語句。

總結

  • 方法一適合簡單場景,字段無需設置為null。

  • 方法二靈活,需嚴格過濾字段。

  • 方法三推薦用于生產環(huán)境,安全且維護性強。

根據(jù)需求選擇合適方案,確保字段更新的靈活性和安全性。

到此這篇關于SpringBoot+MyBatis實現(xiàn)動態(tài)字段更新的三種方法的文章就介紹到這了,更多相關SpringBoot MyBatis字段更新內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • springboot整合持久層的方法實現(xiàn)

    springboot整合持久層的方法實現(xiàn)

    本文主要介紹了springboot整合持久層的方法實現(xiàn),文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-09-09
  • Spring Boot 深入分析AutoConfigurationImportFilter自動化條件配置源碼

    Spring Boot 深入分析AutoConfigurationImportFilter自動化條件

    這篇文章主要分析了Spring Boot AutoConfigurationImportFilter自動化條件配置源碼,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習吧
    2022-07-07
  • Java之BigDecimal的坑及解決

    Java之BigDecimal的坑及解決

    這篇文章主要介紹了Java之BigDecimal的坑及解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-11-11
  • SpringBoot實現(xiàn)初始化的三種策略模式

    SpringBoot實現(xiàn)初始化的三種策略模式

    本文主要介紹了SpringBoot實現(xiàn)初始化的三種策略模式,包括默認初始化策略、懶加載初始化策略和自定義初始化策略,具有一定的參考價值,感興趣的可以了解一下
    2024-12-12
  • 淺談Java 代理機制

    淺談Java 代理機制

    Java 有兩種代理方式,一種是靜態(tài)代理,另一種是動態(tài)代理。如果我們在代碼編譯時就確定了被代理的類是哪一個,那么就可以直接使用靜態(tài)代理;如果不能確定,那么可以使用類的動態(tài)加載機制,在代碼運行期間加載被代理的類這就是動態(tài)代理
    2021-06-06
  • springmvc圖片上傳及json數(shù)據(jù)轉換過程詳解

    springmvc圖片上傳及json數(shù)據(jù)轉換過程詳解

    這篇文章主要介紹了springmvc圖片上傳及json數(shù)據(jù)轉換過程詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2019-10-10
  • Springboot使用maven打包指定mainClass問題

    Springboot使用maven打包指定mainClass問題

    這篇文章主要介紹了Springboot使用maven打包指定mainClass問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-04-04
  • Java和SQL實現(xiàn)取兩個字符間的值

    Java和SQL實現(xiàn)取兩個字符間的值

    這篇文章主要介紹了Java和SQL實現(xiàn)取兩個字符間的值操作,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-06-06
  • maven工程打包引入本地jar包的實現(xiàn)

    maven工程打包引入本地jar包的實現(xiàn)

    我們需要將jar包發(fā)布到一些指定的第三方Maven倉庫,本文主要介紹了maven工程打包引入本地jar包的實現(xiàn),具有一定的參考價值,感興趣的可以了解一下
    2024-02-02
  • Java 線程優(yōu)先級詳解及實例

    Java 線程優(yōu)先級詳解及實例

    這篇文章主要介紹了Java 線程優(yōu)先級詳解及實例的相關資料,需要的朋友可以參考下
    2017-04-04

最新評論