一、循环批处理的foreach标签
foreach元素的属性主要有item,index,collection,open,separator,close。
-
item:集合中元素迭代时的别名,
-
index:集合中元素迭代时的索引
-
open:常用语where语句中,表示以什么开始,比如以'(‘开始
-
separator:表示在每次进行迭代时的分隔符,
-
close 常用语where语句中,表示以什么结束,
在使用foreach的时候最关键的也是最容易出错的就是collection属性,该属性是必须指定的,但是在不同情况下,该属性的值是不一样的,主要有一下3种情况:
-
如果传入的是单参数且参数类型是一个List的时候,collection属性值为list .
-
如果传入的是单参数且参数类型是一个array数组的时候,collection的属性值为array .
-
如果传入的参数是多个的时候,我们就需要把它们封装成一个Map了,当然单参数也可以封装成map,实际上如果你在传入参数的时候,在MyBatis里面也是会把它封装成一个Map的,map的key就是参数名,所以这个时候collection属性值就是传入的List或array对象在自己封装的map里面的key.
针对最后一条,我们来看一下官方说法:
注意 你可以将一个 List 实例或者数组作为参数对象传给 MyBatis,当你这么做的时候,MyBatis 会自动将它包装在一个 Map 中并以名称为键。List 实例将会以“list”作为键,而数组实例的键将是“array”。
所以,不管是多参数还是单参数的list,array类型,都可以封装为map进行传递。如果传递的是一个List,则mybatis会封装为一个list为key,list值为object的map,如果是array,则封装成一个array为key,array的值为object的map,如果自己封装呢,则colloection里放的是自己封装的map里的key值。
// mapper中我们要为这个方法传递的是一个容器,将容器中的元素一个一个的拼接到xml的方法中就要使用这个foreach标签了
public List<User> queryUserList(List<String> userIdList);
// 对应的xml中如下
<select id="queryUserList" resultMap="BaseReslutMap" >
select * FROM User
where id in
<foreach collection="userIdList" item="userId" index="index" open="(" separator="," close=")">
#{userId}
</foreach>
</select>
二、concat模糊查询
实际项目中,肯定会遇到列表筛选的需求,且有些筛选要做到模糊筛选,如下:
// 比如说我们想要进行条件查询,但是几个条件不是每次都要使用,那么我们就可以通过判断是否拼接到sql中
<select id="queryByName" resultType="com.test.java.entity.User">
SELECT * from User
<where>
<if test="name != null and name != ''">
name like concat('%',#{name},'%')
</if>
</where>
</select>
三、choose (when, otherwise)标签
choose标签是按顺序判断其内部when标签中的test条件出否成立,如果有一个成立,则 choose 结束。当 choose 中所有 when 的条件都不满则时,则执行 otherwise 中的sql。类似于Java 的 switch 语句,choose 为 switch,when 为 case,otherwise 则为 default。
例如下面例子,同样把所有可以限制的条件都写上,方面使用。choose会从上到下选择一个when标签的test为true的sql执行。
<!-- 按自定义的排序字段(orderColumn)和排序方式(sortType)进行排序,否则按创建时间(create_time)倒序排序 -->
<select id="queryAgentList" resultType="com.test.java.agent.AgentListVo">
SELECT agent_id,
company_name,
mobile
FROM t_agent
<where>
and data_flag = 1
<if test="agentId != null">
and agent_id = #{agentId}
</if>
<if test="companyName != null and companyName != ''">
and company_name like concat('%', #{companyName}, '%')
</if>
<if test="mobile != null and mobile != ''">
and mobile = #{mobile}
</if>
</where>
<choose>
<when test="orderColumn != null and orderColumn != ''">
order by ${orderColumn} ${sortType}
</when>
<otherwise>
order by create_time desc
</otherwise>
</choose>
</select>
四、if标签
if标签可用在许多类型的sql语句中,我们以查询为例。首先看一个很普通的查询:
<!-- 根据姓名 模糊查询用户 -->
<select id="getUserByName" parameterType="User" resultMap="resultMap">
SELECT * from User
WHERE name LIKE CONCAT('%', #{name},'%')
</select>
但是此时如果name为null,此语句很可能报空指针异常或查询结果为空。此时我们使用if动态sql语句先进行判断,如果值为null或等于空字符串,我们就不进行此条件的判断,增加灵活性。将属性name进行判断,如果不为空则执行判断条件。
<select id="getUserByName" parameterType="User" resultMap="resultMap">
SELECT * from User
WHERE
<if test="name != null and name !='' ">
name LIKE CONCAT('%', #{name},'%')
</if>
</select>
五、Mybatis Plus
mybatis虽然非常方便,但也需要编写大量的SQL语句,于是mybatis plus就应运而生了。它是一个mybatis增强工具,为了简化开发,提高效率。搭配Spring-Boot使用简直不要太爽。
如果这篇文章对您有所帮助,或者有所启发的话,求一键三连:点赞、评论、收藏➕关注,您的支持是我坚持写作最大的动力。
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/161429.html