百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

Spring Boot中使用MyBatis提供的动态SQL语法?

wxin55 2024-11-24 22:37 11 浏览 0 评论

MyBatis的动态SQL是一种在XML文件中通过标签语法动态生成SQL语句的方式,提供了灵活的条件拼接和SQL优化功能,常用于处理复杂的查询条件。而使用动态SQL的好处在于,它能减少硬编码SQL的复杂度,使SQL更加模块化、可读性更强,同时便于维护和扩展。

MyBatis动态SQL语法特点

  • 灵活的条件控制:通过<if>、<choose>...<when>...<otherwise>等标签来判断条件,灵活地组合SQL查询条件。
  • 自动去除多余连接符:使用<where>标签自动处理WHERE条件前的AND或OR,用<set>自动去除更新语句中多余的逗号。
  • 集合处理:通过<foreach>标签处理IN查询、批量插入等场景,便于对集合进行遍历处理。
  • 自定义条件组合:使用<trim>可以自定义去除条件前缀,适合实现复杂的条件组合。

下面我们就来看看如何在SpringBoot项目中使用MyBatis的动态SQL来实现复杂的SQL操作。

基本配置

想要使用MyBatis,就必须要添加MyBatis的配置依赖,如下所示。引入MyBatis依赖和配置MySQL的相关链接。

<!-- pom.xml -->
<dependency>
    <groupId>org.mybatis.spring.boot</groupId>
    <artifactId>mybatis-spring-boot-starter</artifactId>
    <version>2.1.4</version>
</dependency>

然后在application.yml中添加配置数据源和MyBatis相关配置,如下所示,添加MyBatis的相关配置。

# application.yml
mybatis:
  mapper-locations: classpath:mapper/*.xml
  type-aliases-package: com.example.demo.entity

接下来我们可以在src/main/resources/mapper目录下创建Mapper XML文件,例如UserMapper.xml来配置MyBatis动态SQL标签。

常见的动态SQL示例

<if>条件查询

在查询的方法中,我们可以不同的条件来动态的生成对应的SQL语句来实现动态条件查询操作,如下所示。

<!-- UserMapper.xml -->
<select id="findUsers" parameterType="Map" resultType="User">
    SELECT * FROM user
    <where>
        <if test="name != null">
            AND name = #{name}
        </if>
        <if test="age != null">
            AND age = #{age}
        </if>
        <if test="email != null">
            AND email = #{email}
        </if>
    </where>
</select>

调用时传入Map参数,只要name、age或email不为null,相应条件就会被加入SQL中,从而实现动态SQL条件的拼接来实现不同条件的查询操作。

使用<choose>实现多条件判断

<choose>、<when>、<otherwise>:类似Java的switch-case语法,也可以实现动态条件判断实现动态条件查询。如下所示根据status参数值不同,选择不同的查询条件。

<!-- UserMapper.xml -->
<select id="findUsersByStatus" parameterType="map" resultType="User">
    SELECT * FROM user
    <where>
        <choose>
            <when test="status == 'active'">
                AND is_active = 1
            </when>
            <when test="status == 'inactive'">
                AND is_active = 0
            </when>
            <otherwise>
                AND 1 = 1
            </otherwise>
        </choose>
    </where>
</select>

复杂条件查询组合(<where>和<trim>)

  • <where>:自动添加WHERE关键字,并去除多余的AND或OR。
  • <trim>:复杂条件查询组合(<where>和<trim>)
<!-- UserMapper.xml -->
<select id="searchUser" parameterType="User" resultType="User">
    SELECT * FROM user
    <trim prefix="WHERE" prefixOverrides="AND | OR">
        <if test="name != null">
            AND name = #{name}
        </if>
        <if test="age != null">
            AND age = #{age}
        </if>
        <if test="email != null">
            AND email = #{email}
        </if>
    </trim>
</select>

使用<foreach>处理IN查询

用于IN查询或批量插入,遍历集合。如下所示,通过<foreach>标签将id列表转换为IN查询中的参数。

<!-- UserMapper.xml -->
<select id="findUsersByIds" parameterType="list" resultType="User">
    SELECT * FROM user
    WHERE id IN
    <foreach collection="list" item="id" open="(" separator="," close=")">
        #{id}
    </foreach>
</select>

动态更新语句(使用<set>)

使用<set>标签用于UPDATE语句中,自动处理逗号。如下所示,使用<set>标签自动处理最后的多余逗号,从而避免SQL语法错误。

<!-- UserMapper.xml -->
<update id="updateUser" parameterType="User">
    UPDATE user
    <set>
        <if test="name != null">
            name = #{name},
        </if>
        <if test="age != null">
            age = #{age},
        </if>
        <if test="email != null">
            email = #{email},
        </if>
    </set>
    WHERE id = #{id}
</update>

总结

这样在Spring Boot中,我们可以直接注入UserMapper来调用这些方法。MyBatis会自动根据Mapper接口和XML配置生成SQL并执行。

相关推荐

ES6中 Promise的使用场景?(es6promise用法例子)

一、介绍Promise,译为承诺,是异步编程的一种解决方案,比传统的解决方案(回调函数)更加合理和更加强大在以往我们如果处理多层异步操作,我们往往会像下面那样编写我们的代码doSomething(f...

JavaScript 对 Promise 并发的处理方法

Promise对象代表一个未来的值,它有三种状态:pending待定,这是Promise的初始状态,它可能成功,也可能失败,前途未卜fulfilled已完成,这是一种成功的状态,此时可以获取...

Promise的九大方法(promise的实例方法)

1、promise.resolv静态方法Promise.resolve(value)可以认为是newPromise方法的语法糖,比如Promise.resolve(42)可以认为是以下代码的语...

360前端一面~面试题解析(360前端开发面试题)

1.组件库按需加载怎么做的,具体打包配了什么-按需加载实现:借助打包工具(如Webpack的require.context或ES模块动态导入),在使用组件时才引入对应的代码。例如在V...

前端面试-Promise 的 finally 怎么实现的?如何在工作中使用?

Promise的finally方法是一个非常有用的工具,它无论Promise是成功(fulfilled)还是失败(rejected)都会执行,且不改变Promise的最终结果。它的实现原...

最简单手写Promise,30行代码理解Promise核心原理和发布订阅模式

看了全网手写Promise的,大部分对于新手还是比较难理解的,其中几个比较难的点:状态还未改变时通过发布订阅模式去收集事件实例化的时候通过调用构造函数里传出来的方法去修改类里面的状态,这个叫Re...

前端分享-Promise可以中途取消啦(promise可以取消吗)

传统Promise就像一台需要手动组装的设备,每次使用都要重新接线。而Promise.withResolvers的出现,相当于给开发者发了一个智能遥控器,可以随时随地控制异步操作。它解决了三大...

手写 Promise(手写输入法 中文)

前言都2020年了,Promise大家肯定都在用了,但是估计很多人对其原理还是一知半解,今天就让我们一起实现一个符合PromiseA+规范的Promise。附PromiseA+规范地址...

什么是 Promise.allSettled()!新手老手都要会?

Promise.allSettled()方法返回一个在所有给定的promise都已经fulfilled或rejected后的promise,并带有一个对象数组,每个对象表示对应的pr...

前端面试-关于Promise解析与高频面试题示范

Promise是啥,直接上图:Promise就是处理异步函数的API,它可以包裹一个异步函数,在异步函数完成时抛出完成状态,让代码结束远古时无限回掉的窘境。配合async/await语法糖,可...

宇宙厂:为什么前端离不开 Promise.withResolvers() ?

大家好,很高兴又见面了,我是"高级前端进阶",由我带着大家一起关注前端前沿、深入前端底层技术,大家一起进步,也欢迎大家关注、点赞、收藏、转发。1.为什么需要Promise.with...

Promise 新增了一个超实用的 API!

在JavaScript的世界里,Promise一直是处理异步操作的神器。而现在,随着ES2025的发布,Promise又迎来了一个超实用的新成员——Promise.try()!这个新方法简...

一次搞懂 Promise 异步处理(promise 异步顺序执行)

PromisePromise就像这个词的表面意识一样,表示一种承诺、许诺,会在后面给出一个结果,成功或者失败。现在已经成为了主流的异步编程的操作方式,写进了标准里面。状态Promise有且仅有...

Promise 核心机制详解(promise机制的实现原理)

一、Promise的核心状态机Promise本质上是一个状态机,其行为由内部状态严格管控。每个Promise实例在创建时处于Pending(等待)状态,此时异步操作尚未完成。当异步操作成功...

javascript——Promise(js实现promise)

1.PromiseES6开始支持,Promise对象用于一个异步操作的最终完成(包括成功和失败)及结果值的表示。简单说就是处理异步请求的。之所以叫Promise,就是我承诺,如果成功则怎么处理,失败怎...

取消回复欢迎 发表评论: