Java学习 --- mybatisplus配置多数据源

一、mybatisplus配置多数据源

spring:
  # 配置多数据源信息
  datasource:
    # 配置数据源类型
    dynamic:
      # 设置默认数据源或者数据源组
      primary: master
      strict: false
      datasource:
        master:
          url: jdbc:mysql://localhost:3307/mybatis_plus?characterEncoding=utf-8&SSL=false
          driver-class-name: com.mysql.cj.jdbc.Driver
          username: root
          password: 123456
        slave_1:
          url: jdbc:mysql://localhost:3307/mybatis_plus_1?characterEncoding=utf-8&SSL=false
          driver-class-name: com.mysql.cj.jdbc.Driver
          username: root
          password: 123456
mybatis-plus:
  configuration:
    log-impl: org.apache.ibatis.logging.stdout.StdOutImpl
    # 配置统一表的前缀名
  global-config:
    db-config:
      table-prefix: t_
      # 配置全局的主键生成策略
      id-type: auto
  # 配置包的别名
  type-aliases-package: com.cjc.mybatisplus.pojo
  #配置扫描枚举包
  type-enums-package: com.cjc.mybatisplus.enums

二、在service实现类上添加@DS


@Service
@DS("slave_1")
public class ProductServiceImpl extends ServiceImpl<ProductMapper,Product> implements ProductService {
}
@Service
@DS("master")
public class UserServiceImpl extends ServiceImpl<UserMapper, User> implements UserService {
}

三、在pom.xml中添加

 <dependency>
            <groupId>com.baomidou</groupId>
            <artifactId>dynamic-datasource-spring-boot-starter</artifactId>
            <version>3.5.0</version>
        </dependency>

四、测试

@SpringBootTest
public class MultiSourceTest {
    @Autowired
    private UserService userService;
    @Autowired
    private ProductService productService;

    @Test
    public void Test01(){
        User byId = userService.getById(3);
        System.out.println(byId);
        Product byId1 = productService.getById(1);
        System.out.println(byId1);
    }
}

  • 2
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
好的,下面是一个简单的示例,演示如何在 Spring Boot 应用程序中使用 dynamic-datasource-spring-boot-starter 和 mybatisplus 实现多数据操作。 首先,我们需要在 pom.xml 中添加以下依赖: ```xml <dependency> <groupId>com.baomidou</groupId> <artifactId>mybatis-plus-boot-starter</artifactId> <version>3.3.1</version> </dependency> <dependency> <groupId>com.baomidou.dynamic-datasource</groupId> <artifactId>dynamic-datasource-spring-boot-starter</artifactId> <version>2.5.4</version> </dependency> ``` 接着,我们需要在 application.yml 中配置多个数据: ```yaml spring: datasource: driver-class-name: com.mysql.cj.jdbc.Driver dynamic: primary: db1 datasource: db1: url: jdbc:mysql://localhost:3306/db1?useSSL=false&serverTimezone=UTC&allowPublicKeyRetrieval=true username: root password: root db2: url: jdbc:mysql://localhost:3306/db2?useSSL=false&serverTimezone=UTC&allowPublicKeyRetrieval=true username: root password: root ``` 这里我们配置了两个数据,db1 和 db2。 接下来,我们需要创建两个数据对应的 Mapper: ```java @Mapper public interface UserMapper1 extends BaseMapper<User> { List<User> selectAll(); } @Mapper public interface UserMapper2 extends BaseMapper<User> { List<User> selectAll(); } ``` 我们在两个 Mapper 中都定义了一个查询所有用户的方法。 最后,我们需要在 Service 层中使用动态数据mybatisplus: ```java @Service public class UserServiceImpl implements UserService { @Autowired private UserMapper1 userMapper1; @Autowired private UserMapper2 userMapper2; @DS("db1") @Override public List<User> getAllUsersFromDb1() { return userMapper1.selectAll(); } @DS("db2") @Override public List<User> getAllUsersFromDb2() { return userMapper2.selectAll(); } } ``` 在 Service 实现类中,我们使用了 @DS 注解来指定使用哪个数据。当我们调用 getAllUsersFromDb1() 方法时,会使用 db1 数据;调用 getAllUsersFromDb2() 方法时,会使用 db2 数据。 这就是一个简单的使用 dynamic-datasource-spring-boot-starter 和 mybatisplus 实现多数据操作的示例。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

鸭鸭老板

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值