Mybatis的set标签,动态SQL

set标签常用于update语句中,搭配if标签使用

set标签的作用

1、会动态加上前置set关键字

2、可以删除无关的逗号

示例代码:

sql 复制代码
    <update id="update">
        update employee
        <set>
            <if test="name != null">name = #{name},</if>
            <if test="username != null">username = #{username},</if>
            <if test="password != null">password = #{password},</if>
            <if test="phone != null">phone = #{phone},</if>
            <if test="sex != null">sex = #{sex},</if>
            <if test="idNumber != null">id_number = #{idNumber},</if>
            <if test="updateTime != null">update_time = #{updateTime},</if>
            <if test="updateUser != null">update_User = #{updateUser},</if>
            <if test="status != null">status = #{status},</if>
        </set>
        where id = #{id}
    </update>

set标签和if标签的搭配就可以做到有效适应不同的SQL语句

相关推荐
雨中飘荡的记忆16 小时前
Spring状态机深度解析
java·后端·spring
BBB努力学习程序设计16 小时前
Java记录类(Records)与数据建模革命:从POJO到不可变数据的范式转变
java
月屯16 小时前
Pandoc 之--pdf-engine
java·开发语言·pdf
10km16 小时前
java: HashMap.merge 的 Null 值陷阱:为什么 Stream API 会抛出 NPE
java·stream·hashmap·merge
晨星33416 小时前
使用 IntelliJ IDEA 轻松连接 Java 与 MySQL 8 数据库
java·开发语言·数据库
睡觉早点16 小时前
IntelliJ IDEA下载安装过程(含Java环境搭建)
java·ide·jdk·maven·intellij-idea
李少兄16 小时前
IntelliJ IDEA Maven 工具栏消失怎么办?
java·maven·intellij-idea
草酸艾司西酞普兰16 小时前
idea中使用Qoder插件
java·ide·intellij-idea
芽芽_016 小时前
idea无法打开:Cannot collect JVM options
java·ide·intellij-idea