Mybatis动态SQL实战:if、choose、where、set、trim、foreach全解析
5星 · 超过95%的资源 81 浏览量
更新于2024-09-02
收藏 479KB PDF 举报
"Mybatis动态SQL之if、choose、where、set、trim、foreach标记实例详解"
MyBatis是一个流行的持久层框架,它允许开发者将SQL语句直接写在XML配置文件或者Mapper接口的注解中。动态SQL是MyBatis的一个强大特性,可以根据条件动态地生成SQL语句,避免了大量硬编码的条件判断。在MyBatis中,有几种主要的动态SQL标签,包括`if`、`choose`(`when`、`otherwise`)、`where`、`set`、`trim`和`foreach`。下面我们将逐一解析这些标签的用法和实例。
1. if 标签
`if`标签用于根据条件判断是否插入某个片段。例如,在上述描述中,如果用户名不等于"admin",我们需要查询密码为123456的用户。在XML映射文件中,可以这样写:
```xml
<select id="selectUser" parameterType="map" resultType="JiKeUser">
SELECT * FROM user
WHERE 1=1
<if test="username != 'admin'">
AND password = #{password}
</if>
</select>
```
2. choose(when、otherwise)标签
`choose`标签类似于Java的`switch`语句,可以实现多个条件分支。`when`标签用于设置满足某个条件时执行的SQL片段,而`otherwise`标签用于设置当所有条件都不满足时执行的SQL。例如:
```xml
<select id="selectUser" parameterType="map" resultType="JiKeUser">
SELECT * FROM user
WHERE 1=1
<choose>
<when test="username != null">
AND username = #{username}
</when>
<when test="email != null">
AND email = #{email}
</when>
<otherwise>
AND status = 'active'
</otherwise>
</choose>
</select>
```
3. where 标签
`where`标签用于构建`WHERE`子句。当没有条件时,它会自动移除开头的`AND`或`OR`,避免生成无效的SQL。例如:
```xml
<select id="selectUser" parameterType="map" resultType="JiKeUser">
SELECT * FROM user
<where>
<if test="username != null">
username = #{username}
</if>
<if test="email != null">
AND email = #{email}
</if>
</where>
</select>
```
4. set 标签
`set`标签用于构建`SET`子句,在更新语句中使用。它同样会自动处理第一个条件前的`SET`关键字。例如:
```xml
<update id="updateUser" parameterType="JiKeUser">
UPDATE user
<set>
<if test="username != null">
username = #{username},
</if>
<if test="email != null">
email = #{email},
</if>
</set>
WHERE id = #{id}
</update>
```
5. trim 标签
`trim`标签用于删除多余的前缀或后缀。在上述`set`和`where`标签中,其实已经隐含使用了`trim`的功能。但如果你需要自定义删除规则,可以直接使用`trim`。例如,删除所有以特定字符串开头的元素:
```xml
<trim prefix="(" suffix=")" suffixOverrides=",">
<if test="ids != null">
id IN
<foreach item="item" index="index" collection="ids" open="(" separator="," close=")">
#{item}
</foreach>
</if>
</trim>
```
6. foreach 标签
`foreach`标签用于循环遍历集合,生成对应的SQL片段。在上述`trim`示例中,它遍历了`ids`集合,生成了`IN`子句。例如,查询id在列表中的用户:
```xml
<select id="selectUsersByIds" parameterType="java.util.List" resultType="JiKeUser">
SELECT * FROM user
WHERE id IN
<foreach item="item" index="index" collection="list" open="(" separator="," close=")">
#{item}
</foreach>
</select>
```
通过这些动态SQL标签,MyBatis能够灵活地根据传入的参数构建复杂的SQL语句,极大地提高了代码的可读性和维护性。在实际开发中,根据具体需求合理运用这些标签,可以有效地优化数据库操作。
2024-04-28 上传
2012-05-28 上传
点击了解资源详情
2014-11-15 上传
2014-08-27 上传
2016-11-30 上传
2013-03-01 上传
2012-06-24 上传
点击了解资源详情
weixin_38697063
- 粉丝: 6
- 资源: 956
最新资源
- IEEE 14总线系统Simulink模型开发指南与案例研究
- STLinkV2.J16.S4固件更新与应用指南
- Java并发处理的实用示例分析
- Linux下简化部署与日志查看的Shell脚本工具
- Maven增量编译技术详解及应用示例
- MyEclipse 2021.5.24a最新版本发布
- Indore探索前端代码库使用指南与开发环境搭建
- 电子技术基础数字部分PPT课件第六版康华光
- MySQL 8.0.25版本可视化安装包详细介绍
- 易语言实现主流搜索引擎快速集成
- 使用asyncio-sse包装器实现服务器事件推送简易指南
- Java高级开发工程师面试要点总结
- R语言项目ClearningData-Proj1的数据处理
- VFP成本费用计算系统源码及论文全面解析
- Qt5与C++打造书籍管理系统教程
- React 应用入门:开发、测试及生产部署教程