MyBatis的强大特性之一便是它的动态SQL,以前拼接的时候需要注意的空格、列表最后的逗号等,现在都可以不用手动处理了,MyBatis采用功能强大的基于OGNL的表达式来实现,下面主要介绍下。

一、if标签

if是最常用的判断语句,主要用于实现某些简单的条件选择。基本使用示例如下:

  1. <select id="queryAllUsersByName" resultType="com.example.springboot.mybatisxml.entity.User">
  2. select * from user where 1=1
  3. <if test="name != null and name != ''">
  4. and name = #{name}
  5. </if>
  6. <if test="age != null ">
  7. and age = #{age}
  8. </if>
  9. </select>

二、where标签

上面的例子中使用了“1=1”,是为了避免后续条件不满足时候报错,那有没有办法避免这种写法呢?

当然有,就是接下来要说的,标签会自动判断如果包含的标签中有返回值的话,就在sql中插入一个‘where’,如果where标签最后返回的内容是以and 或者or开头的,也会被自动移除掉,上面例子中换成“where”标签后写法如下:

  1. <select id="queryAllUsersByName" resultType="com.example.springboot.mybatisxml.entity.User">
  2. select * from user
  3. <where>
  4. <if test="name != null and name != ''">
  5. and name = #{name}
  6. </if>
  7. <if test="age != null ">
  8. and age = #{age}
  9. </if>
  10. </where>
  11. </select>

三、trim标签

的作用是去除特殊的字符串,它的prefix属性代表语句的前缀,prefixOverrides属性代表需要去除的哪些特殊字符串,prefixOverrides属性会忽略通过管道分隔的文本序列(注意此例中的空格也是必要的),后缀的处理和前缀一样。

trim标签的主要属性如下

  • prefix:前缀覆盖并增加其内容。
  • suffix:后缀覆盖并增加其内容。
  • prefixOverrides:前缀判断的条件。
  • suffixOverrides:后缀判断的条件。

举两个例子。

  1. 使用前缀属性
  1. <select id="queryAllUsersByName" resultType="com.example.springboot.mybatisxml.entity.User">
  2. select * from user
  3. <trim prefix="WHERE" prefixOverrides="AND |OR " >
  4. <if test="name != null and name != ''">
  5. and name = #{name}
  6. </if>
  7. <if test="sex != null ">
  8. or sex = #{sex}
  9. </if>
  10. <if test="age != null ">
  11. and age = #{age}
  12. </if>
  13. </trim>
  14. </select>
  1. 使用后缀属性
  1. <update id="update" parameterType="Object">
  2. UPDATE user
  3. <trim suffix=" SET " suffixOverrides=",">
  4. <if test="id != null ">id=#{id},</if>
  5. <if test="name != null ">name=#{name},</if>
  6. <if test="age != null ">age=#{age},</if>
  7. </trim>
  8. WHERE ID=#{id}
  9. </update>

四、标签

的作用是遍历集合,它能够很好地支持数组和List、Set接口的集合的遍历,往往和sql中的in组合比较多。

foreach标签的主要属性如下

  • item:表示循环中当前的元素。
  • index:表示当前元素在集合的位置下标。
  • collection:配置list的属性名等。
  • open和close:配置的是以什么符号将这些集合元素包装起来。
  • separator:配置的是各个元素的间隔符。

举个例子:

  1. <select id="queryAllUsersByName" resultType="com.example.springboot.mybatisxml.entity.User">
  2. select * from user where id in
  3. <foreach item="id" index="index" collection="userList"
  4. open="(" separator="," close=")">
  5. #{id}
  6. </foreach>
  7. </select>

到此MyBatis的动态SQL的常用功能已经介绍完了,有问题欢迎留言沟通哦!

推荐阅读

1.一分钟带你了解下Spring Security!

2.一分钟带你学会利用mybatis-generator自动生成代码!

3.手把手带你实战下Spring的七种事务传播行为

4.SpringBoot系列-整合Mybatis(注解方式)

5.SpringBoot系列-整合Mybatis(XML配置方式)


Java碎碎念,一个坚持原创的公众号,为您提供一系列系统架构、微服务、Java、SpringBoot、SpringCloud等高质量技术文章。

如果觉得文章不错,希望可以随手转发或者”在看“哦,非常感谢哈!

关注下方公众号后回复「1024」,有惊喜哦!

本文由博客一文多发平台 OpenWrite 发布!

一分钟带你了解下MyBatis的动态SQL!的更多相关文章

  1. Mybatis解析动态sql原理分析

    前言 废话不多说,直接进入文章. 我们在使用mybatis的时候,会在xml中编写sql语句. 比如这段动态sql代码: <update id="update" parame ...

  2. MyBatis框架——动态SQL、缓存机制、逆向工程

    MyBatis框架--动态SQL.缓存机制.逆向工程 一.Dynamic SQL 为什么需要动态SQL?有时候需要根据实际传入的参数来动态的拼接SQL语句.最常用的就是:where和if标签 1.参考 ...

  3. MyBatis的动态SQL详解

    MyBatis的动态SQL是基于OGNL表达式的,它可以帮助我们方便的在SQL语句中实现某些逻辑,本文详解mybatis的动态sql,需要的朋友可以参考下 MyBatis 的一个强大的特性之一通常是它 ...

  4. 使用Mybatis实现动态SQL(一)

    使用Mybatis实现动态SQL 作者 : Stanley 罗昊 [转载请注明出处和署名,谢谢!] 写在前面:        *本章节适合有Mybatis基础者观看* 前置讲解 我现在写一个查询全部的 ...

  5. MyBatis探究-----动态SQL详解

    1.if标签 接口中方法:public List<Employee> getEmpsByEmpProperties(Employee employee); XML中:where 1=1必不 ...

  6. mybatis中的.xml文件总结——mybatis的动态sql

    resultMap resultType可以指定pojo将查询结果映射为pojo,但需要pojo的属性名和sql查询的列名一致方可映射成功. 如果sql查询字段名和pojo的属性名不一致,可以通过re ...

  7. MyBatis的动态SQL详解-各种标签使用

    MyBatis的动态SQL是基于OGNL表达式的,它可以帮助我们方便的在SQL语句中实现某些逻辑. MyBatis中用于实现动态SQL的元素主要有: if choose(when,otherwise) ...

  8. MyBatis中动态SQL元素的使用

    掌握MyBatis中动态SQL元素的使用 if choose(when,otherwise) trim where set foreach <SQL>和<include> 在应 ...

  9. Java-MyBatis:MyBatis 3 动态 SQL

    ylbtech-Java-MyBatis:MyBatis 3 动态 SQL 1.返回顶部 1. 动态 SQL MyBatis 的强大特性之一便是它的动态 SQL.如果你有使用 JDBC 或其它类似框架 ...

随机推荐

  1. PHP ksort

    1.例子一: <?php /** * 根据 c1 对元素排序 */ $arrays = [ 'b' => [ 'c1' => 10, 'c2' => 5, ], 'a' =&g ...

  2. Java自动化测试框架-04 - TestNG之Test Method篇 - 道法自然,法力无边(详细教程)

    简介 按照上一篇的计划,这一篇给小伙伴们分享一下测试方法. 一.设置参数 测试方法是可以带有参数的.每个测试方法都可以带有任意数量的参数,并且可以通过使用TestNG的@Parameters向方法传递 ...

  3. jmeter-控制业务比例

    方式一: 多线程组 缺点:由于各事务相应时间一般不一致,故只能粗略的控制业务占比 实例:待补充

  4. SpringBoot HATEOAS用法简介

    REST风格简介 介绍HATEOAS之前先简单介绍一下REST,REST 是 Representational state transfer 的缩写,翻译过来的意思是表达性状态转换.REST是一种架构 ...

  5. 深入理解 Java 中的 final 关键字

    final 是Java 中重要关键字之一,可以应用于类.方法以及变量上.这篇文章中将讲解什么是 final 关键字?将变量.方法和类声明为 final 代表了什么?使用 final 的好处是什么? f ...

  6. C++ 构造函数的执行过程(一) 无继承

      引言 C++ 构造函数的执行过程(一) 无继承 本篇介绍了在无继承情况下, C++构造函数的执行过程, 即成员变量的构建先于函数体的执行, 初始化列表的数量和顺序并不对构造函数执行顺序造成任何影响 ...

  7. Python 中的for....else....

    在一个for循环中,当循环遇到break语句之后程序就会跳出循环,执行for循环之后的语句:但是,当整个循环都没有遇上break语句,而且你想在这种情况下做一些事情的话,你就可以通过结合else来完成 ...

  8. Mysql数据库(一)数据库设计概述

    1.数据库的体系结构 1.1 数据库系统的三级模式结构是指模式.外模式和内模式. 1.2 三级模式之间的映射分为外模式/模式映射和模式/内模式映射. 2.E-R图也称“实体-关系图”,用于描述现实世界 ...

  9. django-表单之新增字段和设置css属性(四)

    要注意是模板元素 和 表单元素的对应.

  10. carousel.html

    <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...