美文网首页
MyBatis的动态SQL

MyBatis的动态SQL

作者: AI课工场 | 来源:发表于2020-07-29 10:59 被阅读0次

作为一名优秀的Java后端工程师,不得不说,跟数据库打交道的次数比跟自己女朋友(程序猿没有女朋友,原谅我这个不那么恰当的比喻)一起吃饭的次数都多;所以很多程序员对写SQL是深恶痛绝啊,但是回过头来一想,程序在跟数据库进行交互的时候,不就是靠的SQL来完成的吗?如果连SQL都不写了,那还怎么能更好的了解数据库?怎么跟数据库亲切交流呢?后端工程师岂不是要失业了。

基于以上种种,MyBatis作为一个优秀、轻巧、灵活的持久层框架,既解决了我们和数据库交互的繁琐的代码,同时也满足了我们写SQL的愿望(真正是因为我们自己写SQL的可以优化SQL的执行效率),其中最大的一个特点,就是MyBatis的所提供的动态SQL,这也是它有别于其他ORM框架最大的一个特点,相信大家都使用过JDBC或其他类似框架的经验,你应该能体会到根据不同条件拼接SQL语句有多么难受;经常会因为一个空格或者分号等,导致程序运营错误,动态SQL出现彻底的帮我们摆脱这一痛苦。

所以今天这篇文章,就来跟大家聊一聊MyBatis的动态SQL是怎么样一回事儿,是怎么帮广大程序猿节省出时间去陪女朋友的(哦哦哦...我有错了,程序猿没有女朋友...)

MyBatis给我们提供很多的动态SQL语句,这里我们就说几种常用的动态SQL:

<if>

<choose>

<trim>

<foreach>

接下来咱们就分别来介绍下这几种常用的动态SQL。

条件判断语句

首先,我们先来说说标签,这个标签从字面意义上就可以很直观的看出来,它就是一个用来做判断的语句,和Java中的if语句一样,所以它的作用就是用来判断我们拼接的SQL中的条件是否成立,接下来上代码:

<select parameterType="int" resultType="test.User">

      SELECT

          *

      FROM

          t_user

      WHERE 1=1

      <if test="userId !=null and userId !=''">

        and id =   #{userId};

      </if>

    </select>

在这里我们就用来是判断传递过来的参数userId是否为空的情况,这里大家可能注意到一个点,就是有个where 1=1 以及标签里有个and,这是因为,如果我们在使用标签的时候,传递过来的是多个条件,这就需要多个标签了,所以通常情况下我们在每个标签中的条件前面加一个and将它们拼接起来,因为我们不确定那个标签里的条件是满足的,随意where后面第一满足的条件前就多了一个and关键字,所以就通常情况下就会在where后面加上一个1=1恒成立的条件。

注:这里如果大家不使用 1=1的话,可以使用标签,来替换where 1=1 这个等式,将条件写在标签里就可以了。

多条件判断语句

翻译一下就是选择的意思,也就是他可以帮我们在多个条件中选择一个成立的条件,它有点像 Java 中的 switch 语句,一个标签中还需要另外两个重要的标签、 在后面解释,还是先上代码。

<select parameterType="int" resultType="test.User">

      SELECT

      *

      FROM

      t_user

      <where>

        <choose>

          <when test="userId != null and userId != ''">

            and id   =#{userId}

          </when>

          <otherwise>

            and   id=3

          </otherwise>

        </choose>

      </where>

    </select>

这段代码中,我们就直接改掉了标签来代替where 1=1,这里解释下。

当test属性的条件满足时,是执行拼接其内的条件。

所有条件都不满足时,拼接其内的条件。

自定义元素标签

 看标签的名字就能猜个八九不离十了,这个标签可以自定义一些动态SQL的功能,怎么个定义法呢?咱们还是先来上代码,一睹为快。

<select parameterType="int" resultType="test.User">

      SELECT

      *

      FROM

      t_user

      <trim prefix="where"   prefixOverrides="and | or">

        <if test="userId !=null and userId !=''">

          and id =   #{userId};

        </if>

      </trim>

   </select>

还记得我们在说标签的时候,说到的标签吗,用它可以代替where 1=1的情况,现在我们学习了标签的话,也可以用这种方式,标签中有四个属性。

prefix 前缀的意思,上图中我们给的值是where意思就是会这个位置拼接上一个where关键字,当然也可以是别的关键字,如:set

prefixOverrides前覆盖的意思,上图中它会把标签中的and,关键字自动去掉,其他关键字就可以直接用|隔开。

suffix 后缀的意思,和前缀相反,可以在SQL末尾添加执行的后缀。

suffixOverrides 后缀覆盖的意思,和前缀覆盖相反,通常会把SQL最后无用的分号自动去掉。

以上就是标签的用法,它是一个非常灵活的标签,所以通常有些复杂的SQL的时候,就可以用它来处理。

循环标签

这个标签也很容易理解,就是循环的意思,和Java中的for循环类似,只不过它里面的属性多些。

<insert>

      insert into   t_user (name,age) values

      <foreach collection="userList" item="user" separator=",">

          (#{user.username},#{user.age})

      </foreach>

   </insert>

元素的属性主要有item、index、collection、open、separator、close

collection 表示如何来得到这个集合,如果传入的直接为一个List,那么collection值就为list。

如果直接传入的为一个array不可变数组,那么collection值就为array,如果传入的为一个Map,那么collection的值就为map的key。

item 表示集合中每一个元素进行迭代时的别名,比如item为value,那么,每次获取的都使用#{value}即可。

index 指定一个名字,用于表示在迭代过程中,每次迭代到的位置,一般很少使用这个。

open 表示该语句以什么开始。

separator 表示在每次进行迭代之间以什么符号作为分隔符。

close 表示以什么结束。

标签通常用在批量处理的数据的时候,通常是传递一些集合或者数组的参数,在拼接SQL的时候,就需要先从这些集合或数组总循环取出这些数据,比如:批量插入数据,批量删除数据。

好了,到此就把MyBatis最重要也是最核心的一部分内容常用的动态SQL给大家介绍了一下,其中再说一些SQL的事,也会说下相关联的动态SQL标签,这部分知识必须要掌握哦。

喜欢我们的文章吗?还想了解互联网哪些技术,欢迎留言告诉我们

【AI课工场】互联网知识也能如此好玩~

更多热门互联网技术文章抢先知微信公众号【kgc-cn】

相关文章

  • MyBatis动态SQL

    MyBatis 动态SQL 内容 Mybatis动态SQL在XML中支持的几种标签: if chose trim、...

  • MyBatis核心知识点

    (1)Mybatis动态sql是做什么的?都有哪些动态sql?能简述一下动态sql的执行原理不? Mybatis动...

  • MyBatis 动态SQL(*.xml)

    原文参考MyBatis 动态SQL MyBatis的动态SQL大大减少了拼接SQL语句时候的各种格式问题,这里摘录...

  • Mybatis动态SQL

    MyBatis Mybatis笔记连载上篇连接MyBatis缓存Mybatis笔记连载下篇连接 动态SQL 动态S...

  • MyBatis的动态SQL与日志Log4J、SQL语句构造器

    一、MyBatis动态SQL 动态 SQL 是 MyBatis 的强大特性之一。如果你使用过 JDBC 或其它类似...

  • MyBatis学习:动态sql

    1.动态sql 动态sql是mybatis中的一个核心,什么是动态sql?动态sql即对sql语句进行灵活操作,通...

  • 第八章 动态SQL

    动态SQL中的元素介绍 动态SQL有什么作用 MyBatis提供了对SQL语句动态组装的功能 动态SQL中的元素 ...

  • JavaEE基础知识学习----MyBatis(四)动态SQL

    MyBatis的动态SQL MyBatis 的强大特性之一便是它的动态 SQL。如果你有使用 JDBC 或其它类似...

  • 关于Mybatis的一些问题讨论

    Mybatis动态sql是做什么的?都有哪些动态sql?简述一下动态sql的执行原理 动态sql的用途 Mybat...

  • IT 每日一结

    mybatis动态sql 动态sql绝对是mybatis排列前几的闪光点之一。传统代码中的sql语句需要经过多个字...

网友评论

      本文标题:MyBatis的动态SQL

      本文链接:https://www.haomeiwen.com/subject/yckslktx.html