在mybatis中处理集合、循环、数组和in查询等语句的使用

在Mybatis的xml配置中使用集合,主要是用到了foreach动态语句。

foreach的参数:
foreach元素的属性主要有 item,index,collection,open,separator,close。
item表示集合中每一个元素进行迭代时的别名.
index指 定一个名字,用于表示在迭代过程中,每次迭代到的位置.
open表示该语句以什么开始,separator表示在每次进行迭代之间以什么符号作为分隔 符.
close表示以什么结束。

1. Mybatis生成select * from table where id in(1,2,...,n)语句的查询

我们一般的做法是在方法的参数处指定传入的参数名称,在xml中使用的时候,集合的名称要和方法的Param的名称一致,这样便于阅读和理解,然后是在对应的xml文件中使用foreach循环。

java代码如下:

public abstract List<Model> findByIds(@Param("ids")List<Integer> ids);

对应的xml代码如下:

select * from table
<where>
    id in <foreach collection="ids" item="item" index="index" 
open="(" separator="," close=")">#{item}</foreach>
</where>

2.Mybatis保存多条记录

我们同样是通过foreach的方法来实现,这里我们巧妙的利用了sql的语法规则用Mybatis的foreach动态语句来处理。

java代码:

public abstract void saves(@Param("tables")List<Model> tables);

xml代码:

insert into table(name,addtime) values
<foreach collection="tables" item="item" index="index" separator=",">  
    (#{item.name},#{item.addtime})
</foreach>

以上方法Mybatis会帮我们进行sql注入拦截,Mybatis如果采用#{xxx}的形式设置参数,Mybatis会进行sql注入的过滤。如果采用的是${xxx},Mybatis不会进行sql注入过滤,而是直接将参入的内容输出为sql语句。

判断集合是否有值

<if test="list!=null and list.size()>0"></if>

循环删除

循环删除时,要求相应的Mapper方法传递的参数是一个集合(如List),在<delete>标签的参数中设置parameterType="java.util.List",书写sql语句时,使用<foreach>标签循环,其中collection表示Mapper中传递的参数名,item便是循环时压入栈顶的元素,open表示第一次加入的sql前缀,separator表示集合中每个元素之间的分隔符,colse表示循环结束时为sql语句添加的后缀。具体配置如下:

<delete id="deleteList" parameterType="java.util.List">

DELETE FROM CITY WHERE 1 = 1

<foreach collection="list" item="item" open="AND CITY_NO IN(" separator="," close=")">

#{item.cityNo}

</foreach>

</delete>

 

2、mybatis中Mapper方法传递多个参数对象

如果在Mapper中的方法中传递了多个参数对象,可以在service层进行封装(系统的流程为controller->service->mapper),将多个参数封装到map中,用key值进行区别,然后在mapper.xml中的配置如下:

<select id="findByPage" resultMap="listCityMap" parameterType="java.util.Map">

SELECT CITY_NO, CITY_NAME, PROVINCE_NO FROM CITY WHERE 1 = 1

<if test="city.cityNo != null and city.cityNo != '' ">

AND CITY_NO = #{city.cityNo}

</if>

<if test="city.cityName != null and city.cityName != ''">

AND CITY_NAME = #{city.cityName}

</if>

<if test="city.provinceNo != null and city.provinceNo != ''">

AND PROVINCE_NO = #{city.provinceNo}

</if>

LIMIT #{page.startRowNum}, #{page.pageSize}

</select>

其中在Mapper.xml的<select>标签的参数中设置parameterType="java.util.Map",在service方法中,有page和city2个形参,故在service的方法中进行如下处理:

public List<City> findByPage(SimplePage page, City city) {

Map<String, Object> paramMap = new HashMap<String, Object>();

paramMap.put("page", page);

paramMap.put("city", city);

return cityMapper.findByPage(paramMap);

}


  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MyBatis,如果要传递集合、列表、数组或Map等数据结构作为参数,我们可以使用以下方式进行配置和传参: 1. 传递集合或列表参数: 在传递集合或列表参数时,我们可以在SQL语句使用foreach循环遍历每个参数。例如,我们有一个查询语句如下: ``` SELECT * FROM user WHERE id IN (1, 2, 3); ``` 如果我们想要通过集合参数传递id列表,我们的Mapper文件可以这样写: ``` <select id="getUserByIdList" resultType="User"> SELECT * FROM user WHERE id IN <foreach item="id" index="index" collection="idList" open="(" separator="," close=")"> #{id} </foreach> </select> ``` 其,我们通过collection指定了传入的idList集合参数,在foreach标签遍历idList,将每一个id都解析为#{id}参数。这样,就能够动态地构建查询条件,得到期望的查询结果。 2. 传递数组参数: 在传递数组参数时,我们可以通过Java数组语法直接传入参数值,例如: ``` <select id="getUserByIds" resultType="User"> SELECT * FROM user WHERE id IN <foreach item="id" index="index" collection="array" open="(" separator="," close=")"> #{id} </foreach> </select> ``` 在此例,我们通过collection指定了传入的array数组参数,与遍历集合方法类似。 3. 传递Map参数: 如果要传递一个Map作为参数,我们可以为Map的每个键值对设置一个key和value属性,以便在SQL使用。例如: ``` <select id="getUserByMap" resultType="User"> SELECT * FROM user WHERE age = #{age} AND <if test="name!=null">name = #{name}</if> AND <if test="email!=null">email = #{email}</if> </select> ``` 在这个例子,我们通过age、name、email三个键来传递参数值,同时使用if条件语句来根据不同的参数情况动态地构建SQL查询语句。 综上所述,不同的参数类型在MyBatis的传递方式有所不同,但可以通过MyBatis内置的标签,如foreach、if等,来方便地处理动态SQL查询条件的构建。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值