Mybatis中动态SQL,if,where,foreach的使用教程详解

 更新时间:2017年11月08日 17:21:21   投稿:mrr  
MyBatis的动态SQL是基于OGNL表达式的,它可以帮助我们方便的在SQL语句中实现某些逻辑。这篇文章主要介绍了Mybatis中动态SQL,if,where,foreach的使用教程,需要的朋友可以参考下

MyBatis的动态SQL是基于OGNL表达式的,它可以帮助我们方便的在SQL语句中实现某些逻辑。

MyBatis中用于实现动态SQL的元素主要有:

  • if
  • choose(when,otherwise)
  • trim
  • where
  • set
  • foreach

mybatis核心 对sql语句进行灵活操作,通过表达式进行判断,对sql进行灵活拼接、组装。

1、statement中直接定义使用动态SQL:

在statement中利用if 和 where 条件组合达到我们的需求,通过一个例子来说明:

原SQL语句:

<select id="findUserByUserQuveryVo" parameterType ="UserQueryVo" resultType="UserCustom">
 select * from user
 where username = #{userCustom.username} and sex = #{userCustom.sex}
</select>

现在需求是,如果返回值UserCustom为空或者UserCustom中的属性值为空的话(在这里就是userCustom.username或者userCustom.sex)为空的话我们怎么进行灵活的处理是程序不报异常。做法利用if和where判断进行SQL拼接。

<select id="findUserByUserQuveryVo" parameterType ="UserQueryVo" resultType="UserCustom">
 select * from user
<where>
 <if test="userCustom != null">
 <if test="userCustom.username != null and userCustom.username != ''"><!-- 注意and不能大写 -->
  and username = #{userCustom.username}
 </if>
 <if test="userCustom.sex != null and userCustom.sex != ''">
  and sex = #{userCustom.sex}
 </if>
 </if>
</where>
</select>

有时候我们经常使用where 1=1这条语句来处理第一条拼接语句,我们可以使用< where > < where />来同样实现这一功能。

2、使用sql片段来处理statement

和我们写程序一样,有时候会出现一些重复的代码,我们可以用SQL片段来处理。在sql片段中需要注意的是它的位置,我们也可以引用其它mapper文件里面的片段,此时需要我们定义它的位置。

(1)、sql片段的定义

<sql id="query_user_where">
 <if test="sex != null and sex != ''">
  and sex = #{sex}
 </if>
 <if test="id != null">
  and id = #{id}
 </if>
</sql>

(2)、sql片段的使用

<select id="findUserList" parameterType="User" resultType="User">
 select * from user
 <where>
 <!-- 引用Sql片段 -->
 <include refid="query_user_where"></include>
 <!-- 在这里还要引用其它的sql片段 -->
 <!-- 
 where 可以自动去掉条件中的第一个and
 -->
 <!-- <if test="sex != null and sex != ''">
  and sex = #{sex}
 </if>
 <if test="id != null">
  and id = #{id}
 </if> -->
 </where>
</select>

3、使用foreach进行sql语句拼接

在向sql传递数组或List,mybatis使用foreach解析,我们可以使用foreach中元素进行sql语句的拼接,请求数据。

通过一个例子来看:

需求:SELECT * FROM USER WHERE id=1 OR id=10 OR id=16

或者:SELECT * FROM USER WHERE id IN(1,10,16)

<if test="ids != null"> 
 <foreach collection="ids" item="user_id" open="AND (" close=")" separator="or" >
 每次遍历需要拼接的串
  id= #{user_id}
 </foreach>
 </if>

其中,collection:指定输入对象中集合属性,item: 每个遍历生成对象,open:开始遍历时拼接串,close: 结束遍历是拼接的串,separator: 遍历的两个对象中需要拼接的串

<if test="ids != null"> 
 <foreach collection="ids" item="user_id" open="and id IN(" close=")" separator=",">
  id= #{user_id}
 </foreach>
</if>

总结

以上所述是小编给大家介绍的Mybatis中动态SQL,if,where,foreach的使用教程,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!

相关文章

  • java 数据结构中栈和队列的实例详解

    java 数据结构中栈和队列的实例详解

    这篇文章主要介绍了java 数据结构中栈和队列的实例详解的相关资料,主要使用数组与线性表的方法来实现,需要的朋友可以参考下
    2017-09-09
  • java可变参数使用示例

    java可变参数使用示例

    这篇文章主要介绍了java可变参数使用示例,需要的朋友可以参考下
    2014-04-04
  • Mybatis中注入执行sql查询、更新、新增及建表语句案例代码

    Mybatis中注入执行sql查询、更新、新增及建表语句案例代码

    这篇文章主要介绍了Mybatis中注入执行sql查询、更新、新增以及建表语句,主要说明一个另类的操作,注入sql,并使用mybatis执行,结合案例代码详解讲解,需要的朋友可以参考下
    2023-02-02
  • 详谈jpa中表的@OneToMany等关联关系

    详谈jpa中表的@OneToMany等关联关系

    这篇文章主要介绍了详谈jpa中表的@OneToMany等关联关系,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-12-12
  • Java基础之super关键字浅析

    Java基础之super关键字浅析

    java中的super关键字是一个引用变量,用于引用直接父类对象,下面这篇文章主要给大家介绍了关于Java基础之super关键字的相关资料,需要的朋友可以参考下
    2022-04-04
  • Java ynchronized重量级锁的核心原理详解

    Java ynchronized重量级锁的核心原理详解

    这篇文章主要为大家详细介绍了Java ynchronized重量级锁的核心原理,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助
    2022-03-03
  • SpringCloud之Zuul服务网关详解

    SpringCloud之Zuul服务网关详解

    这篇文章主要介绍了SpringCloud之Zuul服务网关详解,服务网关是微服务架构中一个不可或缺的部分,通过服务网关统一向外系统提供REST API的过程中,除了具备服务路由、均衡负载功能之外,它还具备了权限控制(鉴权)等功能,需要的朋友可以参考下
    2023-08-08
  • 引入QQ邮箱发送验证码进行安全校验功能实现

    引入QQ邮箱发送验证码进行安全校验功能实现

    最近遇到这样的需求用户输入自己的邮箱,点击获取验证码,后台会发送一封邮件到对应邮箱中,怎么实现呢?下面小编给大家带来了引入QQ邮箱发送验证码进行安全校验功能,需要的朋友可以参考下
    2023-02-02
  • Spring Cloud下实现用户鉴权的方案

    Spring Cloud下实现用户鉴权的方案

    Java下常用的安全框架主要有Spring Security和shiro,都可提供非常强大的功能,但学习成本较高。但在微服务下鉴权又会对服务有一定的入侵性。 因此,本文将介绍Spring Cloud下实现用户鉴权的方案,感兴趣的同学可以关注一下
    2021-11-11
  • Java使用EasyExcel进行单元格合并的问题详解

    Java使用EasyExcel进行单元格合并的问题详解

    项目中需要导出并合并指定的单元格,下面这篇文章主要给大家介绍了关于java评论、回复功能设计与实现的相关资料,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
    2022-06-06

最新评论