• Mybatisplus-多数据源


    官网链接----->  多数据源 | MyBatis-Plus

    适用于多种场景:纯粹多库、 读写分离、 一主多从、 混合模式等 目前我们就来模拟一个纯粹多库的一个场景,其他场景类似

    场景说明:

    我们创建两个库,分别为:mybatis_plus(以前的库不动)与mybatis_plus_1(新建),将 mybatis_plus库的product表移动到mybatis_plus_1库,这样每个库一张表,通过一个测试用例 分别获取用户数据与商品数据,如果获取到说明多库模拟成功

    1、创建数据库及表

    创建数据库mybatis_plus_1和表product

    1. CREATE DATABASE `mybatis_plus_1` /*!40100 DEFAULT CHARACTER SET utf8mb4 */;
    2. use `mybatis_plus_1`;
    3. CREATE TABLE product
    4. (
    5. id BIGINT(20) NOT NULL COMMENT '主键ID',
    6. name VARCHAR(30) NULL DEFAULT NULL COMMENT '商品名称', price INT(11) DEFAULT 0 COMMENT '价格',
    7. version INT(11) DEFAULT 0 COMMENT '乐观锁版本号', PRIMARY KEY (id)
    8. );

    添加测试数据

    INSERT INTO product (id, NAME, price) VALUES (1, '外星人笔记本', 100);

    删除mybatis_plus库product表

    1. use mybatis_plus;
    2. DROP TABLE IF EXISTS product;

    2、引入依赖(注意加上-多数据源依赖-)

    1. <!--MyBatis-plus启动器-->
    2. <dependency>
    3. <groupId>com.baomidou</groupId>
    4. <artifactId>mybatis-plus-boot-starter</artifactId>
    5. <version>3.5.1</version>
    6. </dependency>
    7. <!--lombok用于简化实体类开发-->
    8. <dependency>
    9. <groupId>org.projectlombok</groupId>
    10. <artifactId>lombok</artifactId>
    11. <optional>true</optional>
    12. </dependency>
    13. <!--mysql驱动-->
    14. <dependency>
    15. <groupId>mysql</groupId>
    16. <artifactId>mysql-connector-java</artifactId>
    17. </dependency>
    18. <!--多数据源依赖-->
    19. <dependency>
    20. <groupId>com.baomidou</groupId>
    21. <artifactId>dynamic-datasource-spring-boot-starter</artifactId>
    22. <version>3.5.0</version>
    23. </dependency>

    3、配置多数据源

    1. spring:
    2. datasource:
    3. # 配置数据源信息 datasource:
    4. dynamic:
    5. # 设置默认的数据源或者数据源组,默认值即为master
    6. primary: master
    7. # 严格匹配数据源,默认false.true未匹配到指定数据源时抛异常,false使用默认数据源
    8. strict: false
    9. datasource:
    10. master:
    11. url: jdbc:mysql://localhost:3306/mybatis_plus?serverTimezone=GMT%2B8&characterEncoding=utf-8&useSSL=false
    12. driver-class-name: com.mysql.cj.jdbc.Driver
    13. username: root
    14. password: 'root'
    15. slave_1:
    16. # 我的数据库是8.0.27 5版本的可以使用jdbc:mysql://localhost:3306/mybatis_plus?characterEncoding=utf-8&useSSL=false
    17. url: jdbc:mysql://localhost:3306/mybatis_plus_1?serverTimezone=GMT%2B8&characterEncoding=utf-8&useSSL=false
    18. driver-class-name: com.mysql.cj.jdbc.Driver
    19. username: root
    20. password: 'root'

    可以使用@DS注解切换数据源

    @DS 可以注解在方法上或类上,同时存在就近原则 方法上注解 优先于 类上注解

    注解结果
    没有@DS默认数据源
    @DS("dsName")dsName可以为组名也可以为具体某个库的名称

    4、创建用户service

    1. public interface UserService extends IService<User> {
    2. }
    1. @Service
    2. @DS("master") // 指定所操作的数据源
    3. public class UserServiceImpl extends ServiceImpl, User> implements UserService {
    4. }

    5、创建商品service

    1. public interface ProductService extends IService<Product> {
    2. }
    1. @Service
    2. @DS("slave_1") // 要操作的数据源
    3. public class ProductServiceImpl extends ServiceImpl, Product> implements ProductService {
    4. }

    6、测试

    记得在启动类中添加注解@MapperScan()

    1. @SpringBootTest
    2. class MybatisPlusDatasourceApplicationTests {
    3. @Autowired
    4. private UserService userService;
    5. @Autowired
    6. private ProductService productService;
    7. @Test
    8. public void test() {
    9. // 测试
    10. System.out.println(userService.getById(1L));
    11. System.out.println(productService.getById(1L));
    12. }
    13. }

  • 相关阅读:
    婴儿摇篮出口美国CPC认证要求
    vue内置组件keep-alive的使用
    【机器学习】使用scikitLearn进行SVM支持向量机线性分类
    spark伪分布部署
    NepCTF2023的wp
    C# 使用正则表达式提取文字
    Java高级:网络编程
    深入浅出Java多线程(十一):AQS
    全网最牛自动化测试框架系列之pytest(3)-测试命名规则
    如何识别和解决PPPoE宽带连接的硬件故障
  • 原文地址:https://blog.csdn.net/weixin_55772633/article/details/133376576