一分钟带你了解下MyBatis的动态SQL!

点击上方“Java碎碎念”,关注公众号

优质文章,第一时间送达

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

一、if标签

if是最常用标签,经常用在判断语句上,可以实现某些简单的条件选择。基本使用示例如下:

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

二、where标签

上面的例子中使用了“1=1”,是为了避免后续条件不满足时候报错,那有没有办法避免这种写法呢?
当然有,就是接下来要说的where,where标签会自动判断如果包含的标签中有返回值的话,就在sql中插入一个where,如果where标签最后返回的内容是以and 或者or开头的,也会被自动移除掉,上面例子中换成where标签后写法如下:

    <select id="queryAllUsersByName" resultType="com.example.springboot.mybatisxml.entity.User">
        select * from user 
        <where>
            <if test="name != null and name != ''">
                and name = #{name}
            </if>
            <if test="age != null ">
                and age = #{age}
            </if>
        </where>
    </select>

三、trim标签

trim的作用是去除特殊的字符串,它的prefix属性代表语句的前缀,prefixOverrides属性代表需要去除的哪些特殊字符串,prefixOverrides属性会忽略通过管道分隔的字符,后缀的处理和前缀一样。

trim标签的主要属性如下

  • prefix:前缀覆盖并增加其内容。

  • suffix:后缀覆盖并增加其内容。

  • prefixOverrides:前缀判断的条件。

  • suffixOverrides:后缀判断的条件。

举两个例子。

  1. 使用前缀属性

    <select id="queryAllUsersByName" resultType="com.example.springboot.mybatisxml.entity.User">
        select * from user
        <trim prefix="WHERE" prefixOverrides="AND |OR " >
            <if test="name != null and name != ''">
                and name = #{name}
            </if>
            <if test="sex != null ">
                or sex = #{sex}
            </if>
            <if test="age != null ">
                and age = #{age}
            </if>
        </trim>
    </select>
  1. 使用后缀属性

<update id="update" parameterType="Object">
        UPDATE user
        <trim prefix=" SET " prefixOverrides=",">
            <if test="id != null ">,id=#{id}</if>
            <if test="name != null ">,name=#{name}</if>
            <if test="age != null ">,age=#{age}</if>
        </trim>
        WHERE ID=#{id}
    </update>

四、foreach标签

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

foreach标签的主要属性如下

  • item:表示循环中当前的元素。

  • index:表示当前元素在集合的位置下标。

  • collection:配置list的属性名等。

  • open和close:配置的是以什么符号将这些集合元素包装起来。

  • separator:配置的是各个元素的间隔符。

举个例子:

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

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

推荐阅读

1.一分钟带你了解下Spring Security!
2.一分钟带你学会利用mybatis-generator自动生成代码!
3.手把手带你实战下Spring的七种事务传播行为
4.SpringBoot系列-整合Mybatis(注解方式)
5.SpringBoot系列-整合Mybatis(XML配置方式)


Java碎碎念,一个坚持原创的公众号,为您提供一系列系统架构、微服务、Java、SpringBoot、SpringCloud等高质量技术文章。
如果觉得文章不错,希望可以随手转发或者”在看“哦,非常感谢哈!
关注下方公众号后回复「1024」,有惊喜哦!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值