在Mybatis中写动态sql这些标签:if、where、set、trim、foreach、choose的作用是什么,怎么用?

在 MyBatis 中,您可以使用动态 SQL 标签来构建灵活的 SQL 查询,以根据不同的条件生成不同的查询语句。以下是这些标签的作用和用法:

  1. **`<if>` 标签:** 用于根据某个条件动态地包含或排除 SQL 片段,test:可以写条件。

示例用法:

```xml

<select id="getUserList" parameterType="Map" resultMap="UserResultMap">

SELECT * FROM users

<where>

<if test="username != null">AND username = #{username}</if>

<if test="email != null">AND email = #{email}</if>

</where>

</select>

```

  1. **`<where>` 标签:** 用于在 SQL 查询中生成 `WHERE` 子句,并自动处理不必要的 `AND` 或 `OR`。

示例用法:

```xml

<select id="getUserList" parameterType="Map" resultMap="UserResultMap">

SELECT * FROM users

<where>

<if test="username != null">AND username = #{username}</if>

<if test="email != null">AND email = #{email}</if>

</where>

</select>

```

  1. **`<set>` 标签:** 用于在更新语句中动态生成 `SET` 子句,根据传入的参数来更新特定的列。

示例用法:

```xml

<update id="updateUser" parameterType="User">

UPDATE users

<set>

<if test="username != null">username = #{username},</if>

<if test="email != null">email = #{email},</if>

</set>

WHERE id = #{id}

</update>

```

  1. **`<trim>` 标签:** 用于在 SQL 语句中修剪多余的空白字符和逗号,并可以根据条件自定义修剪的内容。

prefix:在sql动态条件加前缀

suffix:在sql动态条件加后缀

prefixOverrides:删除sql动态条件前缀内容

suffixOverrides:删除sql动态条件后缀内容

示例用法:

```xml

<select id="getUserList" parameterType="Map" resultMap="UserResultMap">

SELECT * FROM users

<where>

<trim prefix="AND" prefixOverrides="OR">

<if test="username != null">OR username = #{username}</if>

<if test="email != null">OR email = #{email}</if>

</trim>

</where>

</select>

```

  1. **`<foreach>` 标签:** 用于循环遍历集合或数组,生成多个 SQL 片段。

示例用法:

```xml

<select id="getUserListByIds" parameterType="List" resultMap="UserResultMap">

SELECT * FROM users

WHERE id IN

<foreach collection="list" item = "listParam" open = "(" separator = "," close = ")">

#{listParam}

</foreach>

</select>

```

  1. **`<choose>` 标签:** 类似于 Java 中的 `switch` 语句,根据条件选择其中一个分支进行处理。

choose(类似switch)

when标签: 类似switch的case分支 , 需要写test属性

otherwise(否则): 类似switch的default分支

示例用法:

```xml

<select id="getUserList" parameterType="Map" resultMap="UserResultMap">

SELECT * FROM users

<where>

<choose>

<when test="username != null">AND username = #{username}</when>

<when test="email != null">AND email = #{email}</when>

<otherwise>AND status = 1</otherwise>

</choose>

</where>

</select>

```

这些动态 SQL 标签允许您在 MyBatis 中根据不同的条件构建动态的查询语句,以实现更灵活的数据库操作。您可以根据具体的业务需求选择适当的标签来创建定制的查询逻辑。

相关推荐
ClouGence5 小时前
Oracle 数据同步为什么会出现数据不一致?长事务是常被忽略的原因
数据库·后端·oracle
飞将7 小时前
从零实现数据库(2)——HashIndex + IndexManager
数据库
Nturmoils1 天前
订单列表慢查询,先看 WHERE、ORDER BY 和 LIMIT
数据库
渣波1 天前
拒绝 SQL 焦虑!手把手带你用 NestJS + Prisma + DTO 写出“防弹”级后端代码
javascript·数据库·后端
倔强的石头_2 天前
KingbaseES 新版MySQL 兼容版体验:旧版迁移 + 功能实测
数据库
zzzzzz3103 天前
9K Star 炸裂开源!这个 C 语言写的代码知识图谱,把 Linux 内核索引压缩到了 3 分钟
linux·服务器·sql
倔强的石头_5 天前
《Kingbase护城河》——数据库存储空间全景探测与精细化瘦身实战
数据库
云技纵横5 天前
唯一索引 INSERT 死锁实战:5 秒复现交叉插入的 S 锁循环等待
sql·mysql
冬奇Lab6 天前
每日一个开源项目(第134篇):Zvec - 阿里开源的嵌入式向量数据库,向量搜索界的 SQLite
数据库·人工智能·llm
ClouGence6 天前
Oracle CDC 架构优化:从主库直连到 DataGuard 备库同步
数据库·后端·oracle