MyBatis的绝妙用法,舒服!

不管现实多么惨不忍睹,都要持之以恒地相信,这只是黎明前短暂的黑暗而已。不要惶恐眼前的难关迈不过去,不要担心此刻的付出没有回报,别再花时间等待天降好运。真诚做人,努力做事!你想要的,岁月都会给你。MyBatis的绝妙用法,舒服!,希望对大家有帮助,欢迎收藏,转发!站点地址:www.bmabk.com,来源:原文


一、循环批处理的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官网

 

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

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/161429.html

(0)
飞熊的头像飞熊bm

相关推荐

发表回复

登录后才能评论
极客之音——专业性很强的中文编程技术网站,欢迎收藏到浏览器,订阅我们!