Mybatis 常用标签

Posted potent_prince

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Mybatis 常用标签相关的知识,希望对你有一定的参考价值。

MyBatis 的强大特性之一便是它的动态 SQL。如果你有使用 JDBC 或其他类似框架的经验,你就能体会到根据不同条件拼接 SQL 语句有多么痛苦。拼接的时候要确保不能忘了必要的空格,还要注意省掉列名列表最后的逗号。利用动态 SQL 这一特性可以彻底摆脱这种痛苦。

1、<if>

主要用于sql语句拼接(很简单)如示例

2、<choose,when,otherwise>

有些时候,我们不想用到所有的条件语句,而只想从中择其一二。针对这种情况,MyBatis 提供了 choose 元素,它有点像 Java 中的 switch 语句。

结构如下:

<choose>

<when test=" ** ">

<when>

<otherwise>

</otherwise>

</choose>

 

3<where,set>

<update id="updateAuthorIfNecessary">
  update Author
    set
      <if test="username != null">username=#{username},</if>
      <if test="password != null">password=#{password},</if>
      <if test="email != null">email=#{email},</if>
      <if test="bio != null">bio=#{bio}</if>
  where id=#{id}
</update>

 

当我们这样写sql时会出现以下问题

 如果这些条件没有一个能匹配上将会怎样?最终这条 SQL 会变成这样:

 update Author
    set

username=#{username},password=#{password},
where id=#{id}

 

会报错
解决方法有2中
1.加<where ,set>标签
2.<trim>标签

4、<trim>标签

trim标记是一个格式化的标记,可以完成set或者是where标记的功能,如下代码:

  1、

 

 select * from user 

  <trim prefix="WHERE" prefixoverride="AND |OR">

    <if test="name != null and name.length()>0"> AND name=#{name}</if>

    <if test="gender != null and gender.length()>0"> AND gender=#{gender}</if>

  </trim>

 

  假如说name和gender的值都不为null的话打印的SQL为:select * from user where    name = \'xx\' and gender = \'xx\'

  在红色标记的地方是不存在第一个and的,上面两个属性的意思如下:

  prefix:前缀      

  prefixoverride:去掉第一个and或者是or

  2、

  

update user

  <trim prefix="set" suffixoverride="," suffix=" where id = #{id} ">

    <if test="name != null and name.length()>0"> name=#{name} , </if>

    <if test="gender != null and gender.length()>0"> gender=#{gender} ,  </if>

  </trim>

 

  假如说name和gender的值都不为null的话打印的SQL为:update user set name=\'xx\' , gender=\'xx\'     where id=\'x\'

  在红色标记的地方不存在逗号,而且自动加了一个set前缀和where后缀,上面三个属性的意义如下,其中prefix意义如上:

  suffixoverride:去掉最后一个逗号(也可以是其他的标记,就像是上面前缀中的and一样)

  suffix:后缀

5、<foreach>

动态 SQL 的另外一个常用的必要操作是需要对一个集合进行遍历,通常是在构建 IN 条件语句的时候

foreach 元素的功能是非常强大的,它允许你指定一个集合,声明可以用在元素体内的集合项和索引变量。它也允许你指定开闭匹配的字符串以及在迭代中间放置分隔符。这个元素是很智能的,因此它不会偶然地附加多余的分隔符。

注意 你可以将任何可迭代对象(如列表、集合等)和任何的字典或者数组对象传递给foreach作为集合参数。当使用可迭代对象或者数组时,index是当前迭代的次数,item的值是本次迭代获取的元素。当使用字典(或者Map.Entry对象的集合)时,index是键,item是值。


 

以上是关于Mybatis 常用标签的主要内容,如果未能解决你的问题,请参考以下文章

MyBatis动态SQL标签用法

mybatis动态sql之利用sql标签抽取可重用的sql片段

MyBatis高级特性

mybatis框架注解对象怎么在if 标签判断

分享前端开发常用代码片段

mybatis常用标签