zoukankan      html  css  js  c++  java
  • 一分钟带你了解下MyBatis的动态SQL!

    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”,是为了避免后续条件不满足时候报错,那有没有办法避免这种写法呢?
    当然有,就是接下来要说的标签会自动判断如果包含的标签中有返回值的话,就在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标签

    的作用是去除特殊的字符串,它的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 suffix=" SET " suffixOverrides=",">
                <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>
    

    四、标签

    的作用是遍历集合,它能够很好地支持数组和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」,有惊喜哦!

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

  • 相关阅读:
    HashMap源码学习
    java线程池
    MySQL的MVCC
    volatile关键字学习
    ArrayList, Vector和CopyOnWriteArrayList对比学习
    曹工说Redis源码(3)-- redis server 启动过程完整解析(中)
    曹工说Redis源码(2)-- redis server 启动过程解析及简单c语言基础知识补充
    曹工杂谈:我们的应用,启动就要去其他服务拉数据,那其他服务挂了,我们就起不来了?
    程序员正确的提问方式(个人建议)
    曹工说Redis源码(1)-- redis debug环境搭建,使用clion,达到和调试java一样的效果
  • 原文地址:https://www.cnblogs.com/haha12/p/11904224.html
Copyright © 2011-2022 走看看