MyBatis的绝妙用法,舒服!


一、循环批处理的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使用简直不要太爽。

官网:MybatisPlus官网

 

 如果这篇文章对您有所帮助,或者有所启发的话,求一键三连:点赞、评论、收藏➕关注,您的支持是我坚持写作最大的动力。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Javaの甘乃迪

感谢看客老爷的打赏

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值