MyBatis CRUD 常用动态 SQL 标签整理
本文整理了 MyBatis 中进行 CRUD 操作时常用的动态 SQL 标签及其使用方式,适合初学者查阅和实践。
1.<if>:条件判断
用于在满足条件时拼接 SQL 片段。
<select id="selectUser" parameterType="map" resultType="User">
SELECT * FROM user
<where>
<if test="name != null and name != ''">
name = #{name}
</if>
<if test="age != null">
AND age = #{age}
</if>
</where>
</select>
test是唯一属性,使用 OGNL 表达式判断变量是否存在或满足条件。
2.<choose> / <when> / <otherwise>:类似 switch-case
用于多分支选择。
<select id="getUser" parameterType="map" resultType="User">
SELECT * FROM user
<where>
<choose>
<when test="id != null">
id = #{id}
</when>
<when test="name != null">
name = #{name}
</when>
<otherwise>
1 = 1
</otherwise>
</choose>
</where>
</select>
3.<where>:自动处理WHERE和AND
自动去掉首个 AND 或 OR,并在需要时自动加上 WHERE。
<where>
<if test="name != null">name = #{name}</if>
<if test="age != null">AND age = #{age}</if>
</where>
4.<set>:用于UPDATE自动拼接字段
会自动去除最后一个逗号,并加上 SET。
<update id="updateUser" parameterType="User">
UPDATE user
<set>
<if test="name != null">name = #{name},</if>
<if test="age != null">age = #{age},</if>
</set>
WHERE id = #{id}
</update>
5.<foreach>:用于批量操作(插入、删除、IN)
批量插入:
<insert id="batchInsert" parameterType="list">
INSERT INTO user (name, age) VALUES
<foreach collection="list" item="user" separator=",">
(#{user.name}, #{user.age})
</foreach>
</insert>
IN查询:
<select id="selectByIds" parameterType="list" resultType="User">
SELECT * FROM user WHERE id IN
<foreach collection="list" item="id" open="(" separator="," close=")">
#{id}
</foreach>
</select>
6.<trim>:自定义修剪逻辑(替代<set>/<where>)
用于去除开头或结尾的多余 SQL 关键词。
<update id="updateUser" parameterType="User">
UPDATE user
<trim prefix="SET" suffixOverrides=",">
<if test="name != null">name = #{name},</if>
<if test="age != null">age = #{age},</if>
</trim>
WHERE id = #{id}
</update>
到此这篇关于MyBatis CRUD 常用动态 SQL 标签整理的文章就介绍到这了,更多相关MyBatis CRUD 动态 SQL 内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
一文详解为什么越来越多项目开始从JDK 8升级到JDK 21
从JDK 8升级到JDK 21,不仅是版本的迭代,更是开发理念与技术栈的全面革新,这篇文章主要介绍了为什么越来越多项目开始从JDK 8升级到JDK 21的相关资料,需要的朋友可以参考下2026-01-01
基于SqlSessionFactory的openSession方法使用
这篇文章主要介绍了SqlSessionFactory的openSession方法使用,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教2021-12-12
Spring Boot Swagger3常用注解详解与实战指南
Swagger是一个用于设计、构建、文档化和使用RESTful Web服务的开源工具,Swagger3是Swagger的最新版本,它提供了许多新功能和改进,这篇文章主要介绍了Spring Boot Swagger3常用注解详解与实战指南的相关资料,需要的朋友可以参考下2025-10-10
SpringBoot使用JavaMailSender实现发送邮件
JavaMailSender是Spring Framework中的一个接口,用于发送电子邮件,本文主要为大家详细介绍了SpringBoot如何使用JavaMailSender实现发送邮件,需要的可以参考下2023-12-12
解决tomcat启动时报Junit相关错误java.lang.ClassNotFoundException:
这篇文章主要介绍了解决tomcat启动时报Junit相关错误java.lang.ClassNotFoundException: org.junit.Test问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教2025-05-05
Java Web实现session过期后自动跳转到登陆页功能【基于过滤器】
这篇文章主要介绍了Java Web实现session过期后自动跳转到登陆页功能,涉及java过滤器针对session的判断与跳转相关操作技巧,需要的朋友可以参考下2017-11-11


最新评论