SpringBoot+MyBatis实现动态字段更新的三种方法

 更新时间:2025年04月25日 09:30:48   作者:BillKu  
字段更新是指在数据库表中修改特定列的值的操作,这种操作可以通过多种方式进行,具体取决于业务需求和技术环境,本文给大家介绍了在Spring Boot和MyBatis中,实现动态更新不固定字段的三种方法,需要的朋友可以参考下

在Spring Boot和MyBatis中,实现动态更新不固定字段的步骤如下:

方法一:使用MyBatis动态SQL(适合字段允许为null的场景)

定义实体类

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

Mapper接口

定义更新方法,参数为实体对象:

void updateUserSelective(User user);

XML映射文件

使用<set><if>动态生成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,因为参数为null时条件不成立。

方法二:使用Map和字段过滤(支持字段更新为null)

Service层过滤字段

在Service中定义允许更新的字段,并过滤请求参数:

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接收动态字段:

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

XML映射文件

动态生成更新语句:

<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提供类

动态构建安全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);

优点:避免SQL注入,动态生成安全语句。

总结

  • 方法一适合简单场景,字段无需设置为null

  • 方法二灵活,需严格过滤字段。

  • 方法三推荐用于生产环境,安全且维护性强。

根据需求选择合适方案,确保字段更新的灵活性和安全性。

到此这篇关于SpringBoot+MyBatis实现动态字段更新的三种方法的文章就介绍到这了,更多相关SpringBoot MyBatis字段更新内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • springboot整合持久层的方法实现

    springboot整合持久层的方法实现

    本文主要介绍了springboot整合持久层的方法实现,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    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实现初始化的三种策略模式

    SpringBoot实现初始化的三种策略模式

    本文主要介绍了SpringBoot实现初始化的三种策略模式,包括默认初始化策略、懒加载初始化策略和自定义初始化策略,具有一定的参考价值,感兴趣的可以了解一下
    2024-12-12
  • 浅谈Java 代理机制

    浅谈Java 代理机制

    Java 有两种代理方式,一种是静态代理,另一种是动态代理。如果我们在代码编译时就确定了被代理的类是哪一个,那么就可以直接使用静态代理;如果不能确定,那么可以使用类的动态加载机制,在代码运行期间加载被代理的类这就是动态代理
    2021-06-06
  • springmvc图片上传及json数据转换过程详解

    springmvc图片上传及json数据转换过程详解

    这篇文章主要介绍了springmvc图片上传及json数据转换过程详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2019-10-10
  • Springboot使用maven打包指定mainClass问题

    Springboot使用maven打包指定mainClass问题

    这篇文章主要介绍了Springboot使用maven打包指定mainClass问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-04-04
  • Java和SQL实现取两个字符间的值

    Java和SQL实现取两个字符间的值

    这篇文章主要介绍了Java和SQL实现取两个字符间的值操作,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-06-06
  • maven工程打包引入本地jar包的实现

    maven工程打包引入本地jar包的实现

    我们需要将jar包发布到一些指定的第三方Maven仓库,本文主要介绍了maven工程打包引入本地jar包的实现,具有一定的参考价值,感兴趣的可以了解一下
    2024-02-02
  • Java 线程优先级详解及实例

    Java 线程优先级详解及实例

    这篇文章主要介绍了Java 线程优先级详解及实例的相关资料,需要的朋友可以参考下
    2017-04-04

最新评论