Mapper.xml映射文件动态SQL解析

本文详细介绍了MyBatis中Mapper.xml映射文件的动态SQL操作,包括if标签用于条件判断,where标签自动处理首个AND,foreach标签用于遍历数组或List,以及如何使用Sql片段实现SQL重用。通过这些特性,可以灵活地拼接和组装SQL查询条件。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

动态SQl
  mybatis核心 对sql语句进行灵活操作,通过表达式进行判断,对sql进行灵活拼接、组装。对查询条件进行判断,如果输入参数不为空才进行查询条件拼接。

1、if
1
2
3 select * from user
4 where 1=1
5
6 and id=#{id}
7
8
9 and username like ‘%${username}%’
10
11

2、Where
  上面的配置也可以按如下来写:

复制代码
1
2 select * from user
3
4
5 and id=#{id}
6
7
8 and username like ‘%${username}%’
9
10
11

可以自动处理第一个and。

3、foreach

向sql传递数组或List,mybatis使用foreach解析,如下:

如果我们需要传入多个ID来查询多个用户的信息,这也就可以使用foreach。我们先考虑下如果只写sql语句是如下:
  
1 SELECT * FROM USERS WHERE username LIKE ‘%张%’ AND (id =10 OR id =89 OR id=16)
2 SELECT * FROM USERS WHERE username LIKE ‘%张%’ id IN (10,89,16)

index:为数组的下标。
  item:为数组每个元素的名称,名称随意定义
  open:循环开始
  close:循环结束
  separator:中间分隔输出

通过POJO传入List,映射文件如下:

1
2
3 #{id}
4
5
  或者:

1
2
3 id = #{id}
4
5
  传递单个List

传递List类型在编写mapper.xml没有区别,唯一不同的是只有一个List参数时它的参数名为list。

配置文件如下:

select * from user

传递单个数组(数组中是POJO)

<select id="selectUserByArray" parameterType="Object[]" resultType="user">
    select * from user 
    <where>
    <!-- 传递数组 -->
    <if test="array!=null">
    <foreach collection="array" index="index" item="item" open="and id in("separator=","close=")">
        #{item.id} 
    </foreach>
    </if>
    </where>

sql只接收一个数组参数,这时sql解析参数的名称mybatis固定为array,如果数组是通过一个pojo传递到sql则参数的名称为pojo中的属性名。

传递单个数组(数组中是简单类型)

配置文件如下:
1
2
3 select * from user
4
5
6
7 <foreach collection="array"index="index"item="item"open=“and id in(“separator=”,“close=”)”>
8 #{item}
9
10
11
12

如果数组中是简单类型则写为#{item},不用再通过ognl获取对象属性值了。
  
 Sql片段
  Sql中可将重复的sql提取出来,使用时用include引用即可,最终达到sql重用的目的,如下:
  映射文件如下:
1
2
3 select * from user
4
5
6 and id=#{id}
7
8
9 and username like ‘%${username}%’
10
11
12

如果有多个statement都使用相同的查询条件,那么就可以把查询条件抽取出来作为单独的Sql片段。

Sql片段配置:
1
2
3 and id=#{id}
4
5
6 and username like ‘%${username}%’
7
8

使用include引用:**
1
2 select * from user
3
4
5
6

注意:如果引用其它mapper.xml的sql片段,则在引用时需要加上namespace,如下:<include refid="namespace.sql片段”/>

Mapper配置文件中常用的基本属性就是这些,如果还有其他的特殊需求可以根据需要来进行修改配置。另外,在我们的设计中,如果已经定义好了基本的POJO在引用的时候可以在定义一个视图查询层的POJO在其中封装基本的POJO和自定义的POJO(继承基本的POJO),这样就可以较容易实现扩展。当数据库需求有变化的时候可以不修改基本POJO,而修改自定义的POJO,这样就可以实现较好的扩展,而不影响其他模块。如果前端需求有变动,可以通过修改前端的POJO来实现较小的改动。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值