MyBatis之set标签使用及说明

 更新时间:2026年01月30日 10:48:05   作者:JD强子  
MyBatis中update语句使用set标签可以动态更新列,并且可以剔除多余的逗号,if+set标签可以避免某项为null时进行更新

MyBatis之set标签使用

在 Mybatis 中,update 语句可以使用 set 标签动态更新列。set 标签可以为 SQL 语句动态的添加 set 关键字,剔除追加到条件末尾多余的逗号。

使用 if+set 标签修改后

如果某项为 null 则不进行更新,而是保持数据库原值。

如下示例:

<!--  if/set(判断参数) - 将实体 User类不为空的属性更新 -->  
<update id="updateUser_if_set" parameterType="com.pojo.User">  
    UPDATE user  
    <set>  
        <if test="username!= null and username != '' ">  
            username = #{username},  
        </if>  
        <if test="sex!= null and sex!= '' ">  
           sex = #{sex},  
        </if>  
        <if test="birthday != null ">  
            birthday = #{birthday},  
        </if>  
    </set>  
    WHERE user_id = #{userid};      
</update> 

再看看下面的一个示例

<update id="dynamicSetTest" parameterType="Blog">
        update t_blog
        <set>
            <if test="title != null">
                title = #{title},
            </if>
            <if test="content != null">
                content = #{content},
            </if>
            <if test="owner != null">
                owner = #{owner}
            </if>
        </set>
        where id = #{id}
    </update>

set 标签元素主要是用在更新操作的时候,它的主要功能和 where 标签元素其实是差不多的,主要是在包含的语句前输出一个 set,然后如果包含的语句是以逗号结束的话将会把该逗号忽略,如果 set 包含的内容为空的话则会出错。有了 set 元素就可以动态的更新那些修改了的字段。

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • Linux系统下更换jdk版本详细步骤

    Linux系统下更换jdk版本详细步骤

    随着Java语言的不断更新,多个版本的JDK在现在的Linux环境中都存在,使得不同的开发人员可以按照自己的需求使用不同的JDK版本,这篇文章主要给大家介绍了关于Linux系统下更换jdk版本的详细步骤,需要的朋友可以参考下
    2023-12-12
  • Java项目的目录结构详解

    Java项目的目录结构详解

    本文主要介绍了Java项目的目录结构详解,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-02-02
  • SpringBoot中使用Redis案例详解

    SpringBoot中使用Redis案例详解

    文章主要介绍了在SpringBoot项目中的基本配置和文件结构,通过引入案例给大家介绍的非常详细,感兴趣的朋友一起看看吧
    2025-10-10
  • Spring Framework路径遍历漏洞(CVE-2024-38819) 的最新解决方案

    Spring Framework路径遍历漏洞(CVE-2024-38819) 的最新解决方案

    本文介绍SpringFramework 6.1.14+升级方案以修复CVE-2024-38819漏洞,需检查依赖、调整配置、验证兼容性(如JDK17)、测试核心功能及准备回滚计划,确保升级后系统稳定,感兴趣的朋友跟随小编一起看看吧
    2025-08-08
  • Java如何实现数据压缩所有方式性能测试

    Java如何实现数据压缩所有方式性能测试

    本文介绍了多种压缩算法及其在Java中的实现,包括LZ4、BZip2、Deflate、Gzip和7z等,LZ4以其高效的压缩和解压缩速度而受到青睐,特别是在大数据处理场景中,通过对比不同压缩算法的性能和压缩率,我们选择了最适合当前项目需求的压缩工具
    2025-02-02
  • SpringBoot多模块扫描包问题及解决

    SpringBoot多模块扫描包问题及解决

    解决多人协作Spring项目Bean注入问题:确保分包层级正确(Controller在webApplication下),使用@Component、@Service等注解,导入依赖并配置扫描,注意包名错误会导致扫描失败
    2025-10-10
  • spring boot封装HttpClient的示例代码

    spring boot封装HttpClient的示例代码

    这篇文章主要介绍了spring boot封装HttpClient的示例代码,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-01-01
  • SpringBoot如何实现word文档转pdf

    SpringBoot如何实现word文档转pdf

    这篇文章主要介绍了SpringBoot如何实现word文档转pdf,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-07-07
  • IntelliJ IDEA 2020.1.2激活工具下载及破解方法免费可用至2089年(强烈推荐)

    IntelliJ IDEA 2020.1.2激活工具下载及破解方法免费可用至2089年(强烈推荐)

    这篇文章主要介绍了IntelliJ IDEA 2020.1.2激活工具下载及破解方法免费可用至2089年(强烈推荐),本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-09-09
  • 解决spring项目找不到Aspect依赖注解的问题

    解决spring项目找不到Aspect依赖注解的问题

    这篇文章主要介绍了解决spring项目找不到Aspect依赖注解的问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-06-06

最新评论