mybatis动态SQL-choose-when-otherwise

news2024/11/24 8:03:42

1、建库建表

create database `mybatis-example`;
use `mybatis-example`;
create table emp
(
    empNo   varchar(40),
    empName varchar(100),
    sal int,
    deptno varchar(10)
);
insert into emp values('e001','张三',8000,'d001');
insert into emp values('e002','李四',9000,'d001');
insert into emp values('e003','王五',10000,'d001');
insert into emp values('e004','赵六',11000,'d002');
insert into emp values('e005','田七',12000,'d002');
insert into emp values('e006','周八',13000,'d003');
insert into emp values('e007','吴九',14000,'d004');
insert into emp values('e008','郑十',15000,'d004');
insert into emp values('d8f9b794-95ba-11ee-ab75-84a93ea22bfb','张三丰',16000,'d001');

2、pom.xml

    <dependencies>
        <dependency>
            <groupId>org.mybatis</groupId>
            <artifactId>mybatis</artifactId>
        </dependency>
 
        <!-- MySQL驱动 mybatis底层依赖jdbc驱动实现,本次不需要导入连接池,mybatis自带! -->
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
        </dependency>
 
        <!--junit5测试-->
        <dependency>
            <groupId>org.junit.jupiter</groupId>
            <artifactId>junit-jupiter-api</artifactId>
        </dependency>
 
        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
        </dependency>
 
        <!-- 日志 , 会自动传递slf4j门面-->
        <dependency>
            <groupId>ch.qos.logback</groupId>
            <artifactId>logback-classic</artifactId>
        </dependency>
    </dependencies>

3、Emp.java

package com.atguigu.mybatis.pojo;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
@Data
@NoArgsConstructor
@AllArgsConstructor
public class Emp {
    private String empNo;
    private Integer sal;
    private String empName;
    private String deptno;
}

4、EmpMapper.java

package com.atguigu.mybatis.mapper;
import com.atguigu.mybatis.pojo.Emp;
import java.util.List;
public interface EmpMapper {
    //1.演示where-if标签
    List<Emp> getEmpList(Emp emp);

    //2、演示set标签
    void updateEmp(Emp emp);

    //3、演示trim标签
    List<Emp> getEmpList2(Emp emp);

    //4、演示choose/when/otherwise标签
    List<Emp> getEmpList3(Emp emp);
}

5、mybatis-config.xml

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configuration
        PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
        "http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>
 
    <!-- 具体配置 -->
    <!-- 从org.apache.ibatis.session.Configuration类中可以查看能使用的配置项 -->
    <!-- 将mapUnderscoreToCamelCase属性配置为true,表示开启自动映射驼峰式命名规则 -->
    <!-- 规则要求数据库表字段命名方式:单词_单词 -->
    <!-- 规则要求Java实体类属性名命名方式:首字母小写的驼峰式命名 -->
    <settings>
        <setting name="lazyLoadingEnabled" value="true"/>
        <setting name="autoMappingBehavior" value="FULL"/>
        <setting name="mapUnderscoreToCamelCase" value="true"/>
    </settings>
 
    <typeAliases>
        <!--<typeAlias type="com.atguigu.mybatis.pojo.Employee" alias="emp"/>-->
        <package name="com.atguigu.mybatis.pojo"/>
    </typeAliases>
 
    <!-- environments表示配置Mybatis的开发环境,可以配置多个环境,在众多具体环境中,使用default属性指定实际运行时使用的环境。default属性的取值是environment标签的id属性的值。 -->
    <environments default="development">
        <!-- environment表示配置Mybatis的一个具体的环境 -->
        <environment id="development">
            <!-- Mybatis的内置的事务管理器 -->
            <transactionManager type="JDBC"/>
            <!-- 配置数据源 -->
            <dataSource type="POOLED">
                <!-- 建立数据库连接的具体信息 -->
                <property name="driver" value="com.mysql.cj.jdbc.Driver"/>
                <property name="url" value="jdbc:mysql://localhost:3306/mybatis-example"/>
                <property name="username" value="root"/>
                <property name="password" value="123456"/>
            </dataSource>
        </environment>
    </environments>
 
    <mappers>
        <!-- Mapper注册:指定Mybatis映射文件的具体位置 -->
        <!-- mapper标签:配置一个具体的Mapper映射文件 -->
        <!-- resource属性:指定Mapper映射文件的实际存储位置,这里需要使用一个以类路径根目录为基准的相对路径 -->
        <!-- 对Maven工程的目录结构来说,resources目录下的内容会直接放入类路径,所以这里我们可以以resources目录为基准 -->
        <mapper resource="mappers/EmpMapper.xml"/>
    </mappers>
 
</configuration>

6、mappers/EmpMapper.xml

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
        PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
        "https://mybatis.org/dtd/mybatis-3-mapper.dtd">
<!-- namespace等于mapper接口类的全限定名,这样实现对应 -->
<mapper namespace="com.atguigu.mybatis.mapper.EmpMapper">

    <select id="getEmpList" resultType="Emp">
        select * from emp
        <where>
            <if test="empNo!= null">
                empNo=#{empNo}
            </if>
            <if test="empName!= null">
                and empName=#{empName}
            </if>
            <if test="sal!=null">
                and sal &lt; #{sal}
            </if>
            <if test="deptno!=null">
                and deptno=#{deptno}
            </if>
        </where>
        <!--
                select * from emp
                select * from emp WHERE empNo=?
                select * from emp WHERE sal < ?
                select * from emp WHERE empName=?
                select * from emp WHERE deptno=?
                select * from emp WHERE empNo=? and sal < ?
                select * from emp WHERE empNo=? and empName=? and sal < ?
                select * from emp WHERE empNo=? and empName=? and sal < ? and deptno=?
        -->
    </select>

    <update id="updateEmp">
        update emp
        <set>
            <if test="empName!=null">
                empName=#{empName},
            </if>
            <if test="sal!=null">
                sal=#{sal},
            </if>
            <if test="deptno!=null">
                deptno=#{deptno}
            </if>
        </set>
        where empNo=#{empNo}
        <!--
               update emp SET empName=?, sal=?, deptno=? where empNo=?
               update emp SET empName=? where empNo=?
               update emp                    where empNo=?
        -->
    </update>

    <select id="getEmpList2" resultType="Emp">
        select * from emp
        <trim prefix="where" suffix=";" prefixOverrides="or|and" suffixOverrides="or">
            <if test="empNo!=null">
                or empNo=#{empNo} or
            </if>
            <if test="empName!=null">
                or empName=#{empName} or
            </if>
            <if test="sal!=null">
                or sal &lt; #{sal} or
            </if>
            <if test="deptno!=null">
                or deptno=#{deptno} or
            </if>
        </trim>
    </select>

    <select id="getEmpList3" resultType="Emp">
        select * from emp where
        <choose>
            <when test="empNo!=null">
                empNo=#{empNo}
            </when>
            <when test="empName!=null">
                 empName=#{empName}
            </when>
            <when test="sal!=null">
                 sal &lt; #{sal}
            </when>
            <when test="deptno!=null">
                 deptno=#{deptno}
            </when>
            <otherwise>
                1=1
            </otherwise>
        </choose>
    </select>
</mapper>

7、logback.xml

<?xml version="1.0" encoding="UTF-8"?>
<configuration debug="true">
    <!-- 指定日志输出的位置,ConsoleAppender表示输出到控制台 -->
    <appender name="STDOUT"
              class="ch.qos.logback.core.ConsoleAppender">
        <encoder>
            <!-- 日志输出的格式 -->
            <!-- 按照顺序分别是:时间、日志级别、线程名称、打印日志的类、日志主体内容、换行 -->
            <pattern>[%d{HH:mm:ss.SSS}] [%-5level] [%thread] [%logger] [%msg]%n</pattern>
            <charset>UTF-8</charset>
        </encoder>
    </appender>
 
    <!-- 设置全局日志级别。日志级别按顺序分别是:TRACE、DEBUG、INFO、WARN、ERROR -->
    <!-- 指定任何一个日志级别都只打印当前级别和后面级别的日志。 -->
    <root level="DEBUG">
        <!-- 指定打印日志的appender,这里通过“STDOUT”引用了前面配置的appender -->
        <appender-ref ref="STDOUT" />
    </root>
 
    <!-- 根据特殊需求指定局部日志级别,可以是包名或全类名。 -->
    <logger name="com.atguigu.mybatis" level="DEBUG" />
</configuration>

8、MybatisTest.java

package mybatis;
import com.atguigu.mybatis.mapper.EmpMapper;
import com.atguigu.mybatis.pojo.Emp;
import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;
import org.junit.jupiter.api.AfterEach;
import org.junit.jupiter.api.BeforeEach;
import org.junit.jupiter.api.Test;
import java.io.IOException;
import java.io.InputStream;
public class MybatisTest {

    SqlSessionFactory sqlSessionFactory;
    SqlSession sqlSession;
    EmpMapper empMapper;

    @BeforeEach
    public void setup() throws IOException {
        // 获取资源流,读取"mybatis-config.xml"文件
        InputStream inputStream = Resources.getResourceAsStream("mybatis-config.xml");
        // 使用资源流创建SqlSessionFactory
        sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
        // 使用SqlSessionFactory打开一个Session
        sqlSession = sqlSessionFactory.openSession();
        //基于Mapper接口编程
        empMapper=sqlSession.getMapper(EmpMapper.class);
    }

    // 在每个测试用例之后执行的清理方法
    @AfterEach
    public void teardown() {
        sqlSession.commit();  // 提交事务
        sqlSession.close();  // 关闭SqlSession
    }

    @Test
    public void selectWhereIFTest() {
        /**
         * 1、所有条件都不满足
         */
        Emp emp = new Emp();
        empMapper.getEmpList(emp).forEach(System.out::println);//select * from emp
        //Emp(empNo=e001, sal=8000, empName=张三, deptno=d001)
        //Emp(empNo=e002, sal=9000, empName=李四, deptno=d001)
        //Emp(empNo=e003, sal=10000, empName=王五, deptno=d001)
        //Emp(empNo=e004, sal=11000, empName=赵六, deptno=d002)
        //Emp(empNo=e005, sal=12000, empName=田七, deptno=d002)
        //Emp(empNo=e006, sal=13000, empName=周八, deptno=d003)
        //Emp(empNo=e007, sal=14000, empName=吴九, deptno=d004)
        //Emp(empNo=e008, sal=15000, empName=郑十, deptno=d004)
        //Emp(empNo=d8f9b794-95ba-11ee-ab75-84a93ea22bfb, sal=16000, empName=张三丰, deptno=d001)

        /**
         * 2、一个条件满足
         */
        Emp emp1 = new Emp();
        emp1.setEmpNo("e002");
        empMapper.getEmpList(emp1).forEach(System.out::println);//select * from emp WHERE empNo=?
        //Emp(empNo=e002, sal=9000, empName=李四, deptno=d001)

        Emp emp2 = new Emp();
        emp2.setSal(11000);
        empMapper.getEmpList(emp2).forEach(System.out::println);//select * from emp WHERE sal < ?
        //Emp(empNo=e001, sal=8000, empName=张三, deptno=d001)
        //Emp(empNo=e002, sal=9000, empName=李四, deptno=d001)
        //Emp(empNo=e003, sal=10000, empName=王五, deptno=d001)

        Emp emp3 = new Emp();
        emp3.setEmpName("张三丰");
        empMapper.getEmpList(emp3).forEach(System.out::println);//select * from emp WHERE empName=?
        //Emp(empNo=d8f9b794-95ba-11ee-ab75-84a93ea22bfb, sal=16000, empName=张三丰, deptno=d001)

        Emp emp4 = new Emp();
        emp4.setDeptno("d001");
        empMapper.getEmpList(emp4).forEach(System.out::println);//select * from emp WHERE deptno=?
        //Emp(empNo=e001, sal=8000, empName=张三, deptno=d001)
        //Emp(empNo=e002, sal=9000, empName=李四, deptno=d001)
        //Emp(empNo=e003, sal=10000, empName=王五, deptno=d001)
        //Emp(empNo=d8f9b794-95ba-11ee-ab75-84a93ea22bfb, sal=16000, empName=张三丰, deptno=d001)

        /**
         * 2、两个条件满足
         */
        Emp emp5 = new Emp();
        emp5.setEmpNo("e002");
        emp5.setSal(11000);
        empMapper.getEmpList(emp5).forEach(System.out::println);//select * from emp WHERE empNo=? and sal <?
        //Emp(empNo=e002, sal=9000, empName=李四, deptno=d001)

        /**
         * 3、三个条件都满足,以次类推
         */
        Emp emp6 = new Emp();
        emp6.setEmpNo("e002");
        emp6.setSal(11000);
        emp6.setEmpName("张三丰");
        empMapper.getEmpList(emp6).forEach(System.out::println);//select * from emp WHERE empNo=? and empName=? and sal < ?


        /**
         * 4、全部条件满足
         */
        Emp emp100 = new Emp("e001",8001,"张三","d001");
        empMapper.getEmpList(emp100).forEach(System.out::println);//select * from emp WHERE empNo=? and empName=? and sal < ? and deptno=?
        //Emp(empNo=e001, sal=8000, empName=张三, deptno=d001)
    }

    @Test
    public void updateSetIfTest() {

        /**
         * 1、所有条件都满足
         */
        Emp emp = new Emp("e001",4000,"张三","d001");
        empMapper.updateEmp(emp);//update emp SET empName=?, sal=?, deptno=? where empNo=?

        /**
         * 2、部分条件满足
         */
        Emp emp1 = new Emp();
        emp1.setEmpNo("e002");
        emp1.setEmpName("张无忌");
        empMapper.updateEmp(emp1);//update emp SET empName=? where empNo=?

        /**
         * 3、所有条件都不满足,报错SQLSyntaxErrorException
         */
        Emp emp2 = new Emp();
        emp2.setEmpNo("e003");
        empMapper.updateEmp(emp2);

    }

    @Test
    public void trimTest() {
        Emp emp = new Emp();
        empMapper.getEmpList2(emp).forEach(System.out::println);//select * from emp

        Emp emp1 = new Emp();
        emp1.setEmpNo("e001");
        empMapper.getEmpList2(emp1).forEach(System.out::println);//select * from emp where empNo=? ;
    }

    @Test
    public void chooseWhenTest() {

        Emp emp1 = new Emp();
        empMapper.getEmpList3(emp1).forEach(System.out::println);//select * from emp where 1=1

        Emp emp2 = new Emp();
        emp2.setEmpNo("e001");
        empMapper.getEmpList3(emp2).forEach(System.out::println);//select * from emp where empNo=?

        Emp emp3 = new Emp();
        emp3.setEmpNo("e002");
        emp3.setEmpNo("李四");
        empMapper.getEmpList3(emp3).forEach(System.out::println);//select * from emp where empNo=?
    }
}

 9、choose/when/otherwise标签

在MyBatis中,choosewhen, 和 otherwise 标签是用于条件判断的。它们可以组合在一起,形成一个条件判断的链式结构。

  1. choose 标签:

    • choose 标签内部可以包含多个 when 和/或 otherwise 子标签。
    • 当所有条件都不满足时,会执行 otherwise 中的内容。
    • 可以使用 otherwise 标签来指定默认的操作或返回值。
  2. when 标签:

    • when 标签用于判断条件是否满足。
    • 如果条件满足,则执行 when 标签中的内容。
    • 条件表达式可以使用 MyBatis 的动态 SQL 语法,例如 ${variable} 或 ${#variable}
  3. otherwise 标签:

    • 当所有条件都不满足时,会执行 otherwise 标签中的内容。
    • otherwise 标签通常用于提供一个默认的选项或值。

下面是一个简单的示例,展示了如何使用这些标签:

<select id="selectUsers" resultType="User">  
  SELECT * FROM user  
  WHERE 1=1  
  <choose>  
    <when test="name != null">  
      AND name = #{name}  
    </when>  
    <when test="age != null">  
      AND age = #{age}  
    </when>  
    <otherwise>  
      AND status = 'ACTIVE'  
    </otherwise>  
  </choose>  
</select>

在上面的示例中,我们根据不同的条件来构建查询语句。如果 name 不为空,则添加一个条件来过滤名字;如果 age 不为空,则添加一个条件来过滤年龄。如果两个条件都为空,则使用默认的条件来过滤状态为 'ACTIVE' 的用户。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1307738.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

线性代数基础【2】矩阵

第二章 矩阵 第一节 矩阵的基本概念与特殊矩阵 一、基本概念 ①矩阵 像如下图示的为矩阵,记为A(aij)m*n ②同型矩阵及矩阵相等 若A、B为如下两个矩阵 如果A和B的行数和列数相等,那么A和B为同型矩阵,且A和B的元素相等(即:aijbij),则称A和B相等 ③伴随矩阵 设A为mn矩阵(如上…

论文润色突显研究亮点 papergpt

大家好&#xff0c;今天来聊聊论文润色突显研究亮点&#xff0c;希望能给大家提供一点参考。 以下是针对论文重复率高的情况&#xff0c;提供一些修改建议和技巧&#xff1a; 标题&#xff1a;论文润色突显研究亮点――提升论文吸引力的关键步骤 一、引言 在学术研究中&#x…

常用的建表但范式、反规范化

规范化&#xff1a; 规范化是用于数据库设计的一系列原理和技术&#xff0c;它可以减少表中数据的冗余&#xff0c;增加数据完整性和一致性。通常有很多范式。 第一范式&#xff08;1NF&#xff09;&#xff1a; 常用的三种范式&#xff1a; 表中的字段都是不可再分割的原子属…

math.gamma()

伽马函数 将阶乘一般化&#xff0c;即将阶乘推广到实数域。 gamma(x) integral(0 to inf) of t^(x-1) * exp(-t) dt 不推了&#xff0c;总之就是表示阶乘

计网Lesson10 - 网络层之IP协议分析

文章目录 网络层协议IPv4 数据报格式IPv4 数据报首部格式版本&#xff08;Version&#xff09;首部长度&#xff08;Header Length&#xff09;区分服务&#xff08;Differentiated Services Field&#xff09;可选字段填充总长度&#xff08;Total Length&#xff09;标识、标…

JavaEE进阶学习: SpringBoot 日志文件

1.日志有什么用 日志的主要作用是记录系统的运行状态、事件和错误信息等。具体来说&#xff0c;日志可以用于以下几个方面&#xff1a; 故障排除&#xff1a;当系统出现故障或错误时&#xff0c;日志可以帮助开发人员定位问题的具体原因和位置&#xff0c;从而更快地修复系统。…

计算机网络简答题

面向连接和非连接的服务特点 面向连接的服务&#xff1a;通信双方在进行通信之前&#xff0c;要事先建立一个完整的可以彼此沟通的通道&#xff0c;在通信过程中整个连接的情况可以被实时的监控和管理 面向非链接的服务&#xff1a;不需要预先建立一个联络两个通信节点的连接&a…

【obs】官方最强插件obs-websocket入门

▒ 目录 ▒ &#x1f6eb; 导读需求开发环境 1️⃣ obs-websocket简介OBS版本说明obs-websocket版本说明安装&#xff08;27.x版本OBS&#xff09;配置插件 2️⃣ OBS-web介绍特征使用方法-5.xhttp vs https 3️⃣ obs-websocket-js开发tester.html 4️⃣ 其它开源项目obs-stud…

做题笔记:SQL Sever 方式做牛客SQL的题目--查询每天刷题通过数最多的前二名用户

----查询每天刷题通过数最多的前二名用户id和刷题数 现有牛客刷题表questions_pass_record&#xff0c;请查询每天刷题通过数最多的前二名用户id和刷题数&#xff0c;输出按照日期升序排序&#xff0c;查询返回结果名称和顺序为&#xff1a; date|user_id|pass_count 表单创建…

双指针的运用——双数之和II和三数之和

两数之和 https://leetcode.cn/problems/two-sum-ii-input-array-is-sorted/description/ 我们考虑这个排序过的数组&#xff0c;首先一个指针在最左&#xff0c;一个在最右。如果这两个数字比目标数字来的要小&#xff0c;那么如果我们左边指针移动了&#xff0c;移动后一定变…

高通平台开发系列讲解(USB篇)linux下如何让U盘可以识别问题

文章目录 一、简述二、修改方法三、宏介绍沉淀、分享、成长,让自己和他人都能有所收获!😄 一、简述 对于一些U盘不能自动被Linux内核识别的情况,可能需要进行一些调整和修改内核驱动的设置。 二、修改方法 在kernel中开启以下的宏开关 CONFIG_USB_STORAGE=y CONFIG_SCSI=…

uniapp原生插件之安卓app添加到其他应用打开原生插件

插件介绍 安卓app添加到其他应用打开原生插件&#xff0c;接收分享的文本和文件&#xff0c;支持获取和清空剪切板内容 插件地址 安卓app添加到其他应用打开原生插件&#xff0c;支持获取剪切板内容 - DCloud 插件市场 超级福利 uniapp 插件购买超级福利 详细使用文档 u…

第三届《我们的世界》---2023 国际当代艺术展在广州沙面隆重启幕

开幕快讯 2023年12月10日下午,由法国表现主义画院与东方荟萃艺术学院 联合主办的,由法中艺术交流协会、香港博物馆世界、让米歇尔艺术空 间共同协办,法国驻广州总领事馆支持的第三届《我们的世界》---2023 国际当代艺术展在广州沙面隆重启幕! 嘉宾签到现场 本次展览集合了30位活…

50.0/表格(详细版)

目录 50.1 建立表格 50.2 表格边框 50.3 设置表格或单元格的宽度和高度 50.4 表格的背景设置 50.5 表格边框颜色的设置 50.6 表格的位置 50.6.1 水平位置 50.6.2 垂直位置 50.7 为表格添加表头和标题 50.8 单元格的合并 50.8.1 跨行 50.8.2 跨列 50.9 综合示例 通…

Android---Kotlin 学习005

substring 字符串截取。相加与 java&#xff0c;kt 里面的 substring 函数支持 IntRange 类型&#xff08;表示一个整数范围的类型&#xff09;的参数&#xff0c;until 创建的范围不包括上限值。 const val NAME "Jimmys friend" fun main(){val index NAME.ind…

python 安装对应版本的lxml

安装对应版本的lxml 先把对应版本的lxml文件下载下来&#xff0c;接着在文件夹路径输入cmd回车&#xff0c;用下面命令安装。

《洛谷深入浅出进阶篇》 进阶数论

本文章内容比较长&#xff0c;请耐心食用&#xff01;&#xff01;&#xff01;&#xff01;&#xff01; 目录&#xff1a; 模意义下的数和运算喵~ 模意义下的乘法逆元喵~ 同余方程与中国剩余定理喵~ 线性筛与积性函数喵~ 欧拉函数喵~ 一&#xff0c;模意义下的数和运算。…

Android : Room 数据库的基本用法 —简单应用_一_入门

1.Room介绍&#xff1a; Android Room 是 Android 官方提供的一个持久性库&#xff0c;用于在 Android 应用程序中管理数据库。它提供了一个简单的 API 层&#xff0c;使得使用 SQLite 数据库变得更加容易和方便。 以下是 Android Room 的主要特点&#xff1a; 对象关系映射…

Ajax原理以及优缺点

Ajax原理 1.Ajax的原理简单来说是在用户和服务器之间加了—个中间层(AJAX引擎)&#xff0c;通过XmlHttpRequest对象来向服务器发异步请求&#xff0c; 2.从服务器获得数据&#xff0c;然后用javascript来操作DOM而更新页面。使用户操作与服务器响应异步化。 3.这其中最关键的一…

SpringBoot 实现动态切换数据源

最近在做业务需求时&#xff0c;需要从不同的数据库中获取数据然后写入到当前数据库中&#xff0c;因此涉及到切换数据源问题。本来想着使用Mybatis-plus中提供的动态数据源SpringBoot的starter&#xff1a;dynamic-datasource-spring-boot-starter来实现。 结果引入后发现由于…