springboot,mysql多数据源-mybaits

为啥要多数据源,因为我现在有个需求,需要将A库的查询结果,写入到B库。

但是原来的springboot里面就只有A库,所以现在要加上B库。


1.修改application.yaml的数据库连接

这个是原来的

现在改成

其实就是将datasource:xxx,改成了datasource:aku:xxx 然后【同级】加了一个bku:xxx。

还有要把url改成jdbc-url 。application的datasource下的url要换成jdbc-url。多数据的话必须换成这个

2.在resource的mapper里创建2个mapper文件夹

将原来默认的mapper下的,内容放到aku下,此时发现变灰,因为mapper路径被改了,下一步会重新配置映射

java代码包mapper的包里,也【创建】2个package

同样,把原来mapper的interface的java文件复制到aku里。

3.修改application.yaml的mybaits配置,重新配置映射

注意红色部分是我新加的,这样就重新映射上了

复制代码
mybatis:
  mapper-locations: classpath:/mapper/**/*.xml
  configuration:
    map-underscore-to-camel-case: true

4.创建2个源连接,主库和从库的

以前是不需要配置的,因为会走默认配置,现在有2个了,你就得写2个,并且告诉他们对应的mapper是哪个。

随便找个文件夹创建一下,我在我自己的config里面创建下面2个程序

AkuDataSourceConfig

java 复制代码
package com.example.demo.config;

import org.apache.ibatis.session.SqlSessionFactory;
import org.mybatis.spring.SqlSessionFactoryBean;
import org.mybatis.spring.annotation.MapperScan;
import org.springframework.beans.factory.annotation.Qualifier;
import org.springframework.boot.context.properties.ConfigurationProperties;
import org.springframework.boot.jdbc.DataSourceBuilder;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.context.annotation.Primary;
import org.springframework.core.io.Resource;
import org.springframework.core.io.support.PathMatchingResourcePatternResolver;
import org.springframework.jdbc.datasource.DataSourceTransactionManager;

import javax.sql.DataSource;
@Configuration
@MapperScan(basePackages = "com.example.demo.mapper.aku", sqlSessionFactoryRef = "masterSqlSessionFactory")
public class AkuDataSourceConfig {

    @Primary
    @Bean("masterDataSource")
    @ConfigurationProperties(prefix = "spring.datasource.master")
    public DataSource masterDataSource() {
        return DataSourceBuilder.create().build();
    }

    @Primary
    @Bean("masterDataSourceTransactionManager")
    public DataSourceTransactionManager masterDataSourceTransactionManager(@Qualifier("masterDataSource") DataSource dataSource) {
        return new DataSourceTransactionManager(dataSource);
    }

    @Primary
    @Bean("masterSqlSessionFactory")
    public SqlSessionFactory masterSqlSessionFactory(@Qualifier("masterDataSource") DataSource dataSource) throws Exception {
        SqlSessionFactoryBean sqlSessionFactory = new SqlSessionFactoryBean();
        sqlSessionFactory.setDataSource(dataSource);
        Resource[] resources = new PathMatchingResourcePatternResolver().getResources("classpath:mapper/aku/*.xml");
        sqlSessionFactory.setMapperLocations(resources);

        return sqlSessionFactory.getObject();
    }

}
复制代码
只用注意这3个地方改一下,标红的,分别对应的是interface,mapper.xml还有application.yaml

@MapperScan(basePackages = "com.example.demo.mapper.aku", sqlSessionFactoryRef = "masterSqlSessionFactory")
复制代码
PathMatchingResourcePatternResolver().getResources("classpath:mapper/aku/*.xml");
复制代码
@ConfigurationProperties(prefix = "spring.datasource.aku")

BkuDataSourceConfig

java 复制代码
package com.example.demo.config;

import org.apache.ibatis.session.SqlSessionFactory;
import org.mybatis.spring.SqlSessionFactoryBean;
import org.mybatis.spring.annotation.MapperScan;
import org.springframework.beans.factory.annotation.Qualifier;
import org.springframework.boot.context.properties.ConfigurationProperties;
import org.springframework.boot.jdbc.DataSourceBuilder;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.context.annotation.Primary;
import org.springframework.core.io.Resource;
import org.springframework.core.io.support.PathMatchingResourcePatternResolver;
import org.springframework.jdbc.datasource.DataSourceTransactionManager;

import javax.sql.DataSource;

@Configuration
@MapperScan(basePackages = "com.example.demo.mapper.bku", sqlSessionFactoryRef = "slaveSqlSessionFactory")
public class BkuDataSourceConfig {

    @Bean("slaveDataSource")
    @ConfigurationProperties(prefix = "spring.datasource.slave")
    public DataSource slaveDataSource() {
        return DataSourceBuilder.create().build();
    }

    @Bean("slaveDataSourceTransactionManager")
    public DataSourceTransactionManager slaveDataSourceTransactionManager(@Qualifier("slaveDataSource") DataSource dataSource) {
        return new DataSourceTransactionManager(dataSource);
    }

    @Bean("slaveSqlSessionFactory")
    public SqlSessionFactory slaveSqlSessionFactory(@Qualifier("slaveDataSource") DataSource dataSource) throws Exception {
        SqlSessionFactoryBean sqlSessionFactory = new SqlSessionFactoryBean();
        sqlSessionFactory.setDataSource(dataSource);
        Resource[] resources = new PathMatchingResourcePatternResolver().getResources("classpath:mapper/bku/*.xml");
        sqlSessionFactory.setMapperLocations(resources);

        return sqlSessionFactory.getObject();
    }


}

b库复制这段代码后,需要改的也是类似a库标红的地方。

5.启动测试

成功

用的时候导入不同的mapper,就可以了。

参考:Spring Boot整合MyBatis配置多数据源-CSDN博客

相关推荐
czlczl2002092519 小时前
通过哪些条件确定用哪个消息转换器
spring boot
爱吃面条的猿19 小时前
MySQL 随机日期/时间生成
数据库·mysql
2501_9399090519 小时前
Mysql 主从复制、读写分离
数据库·mysql
k***825119 小时前
图文详述:MySQL的下载、安装、配置、使用
android·mysql·adb
毕设源码-朱学姐19 小时前
【开题答辩全过程】以 个人健康管理系统为例,包含答辩的问题和答案
java·spring boot
qq_124987075319 小时前
基于微信小程序的线下点餐系统的设计与实现(源码+论文+部署+安装)
spring boot·微信小程序·小程序·毕业设计
IT_Octopus20 小时前
Java GZip 压缩实践 +实践思考 +进一步压榨性能和存储方案思考:Protobuf+ GZip
java·spring boot
wstcl20 小时前
通过EF Core将Sql server数据表移植到MySql
数据库·mysql·sql server·efcore
故渊ZY20 小时前
从入门到精通:MySQL 核心技术与业务落地实践
mysql
计算机毕设匠心工作室20 小时前
【python大数据毕设实战】全面皮肤病症状数据可视化分析系统、Hadoop、计算机毕业设计、包括数据爬取、数据分析、数据可视化、机器学习、实战教学
后端·python·mysql