随笔 - 547  文章 - 1  评论 - 295  阅读 - 33万

springboot项目配置多数据源

springboot项目配置多数据源

//关键:mybatis文件的目录需要区分开来
sqlSessionFactoryBean.setMapperLocations(new PathMatchingResourcePatternResolver().getResources("classpath:mybatis.myProjectOne/*.xml"));

#从数据库配置,数据库的配置 以spring.datasource.myProjectOne前缀,需要配置驱动程序名称。
spring.datasource.myProjectOne.driver-class-name = com.mysql.jdbc.Driver
spring.datasource.myProjectOne.url = jdbc:mysql://IP:3306/databaseName?useUnicode=true&characterEncoding=UTF8&zeroDateTimeBehavior=convertToNull&autoReconnect=true&allowMultiQueries=true&useSSL=false
spring.datasource.myProjectOne.username = username
spring.datasource.myProjectOne.password = password

从数据源

复制代码
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.autoconfigure.jdbc.DataSourceBuilder;
import org.springframework.boot.context.properties.ConfigurationProperties;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.context.annotation.Primary;
import org.springframework.core.io.support.PathMatchingResourcePatternResolver;
import org.springframework.jdbc.datasource.DataSourceTransactionManager;
import org.springframework.transaction.support.TransactionTemplate;

import javax.sql.DataSource;

/**
 * 数据源配置
 */
@Configuration
@MapperScan(basePackages = "com.my.projectOne.mapper", sqlSessionFactoryRef = "myProjectOneDBSessionFactory")
public class OneDBConfig {

    @Bean(name = "myProjectOneDataSource")
    @ConfigurationProperties(prefix = "spring.datasource.myProjectOne")
    @Primary
    public DataSource fundsDataSource() {
        return DataSourceBuilder.create().build();
    }


    @Bean(name = "myProjectOneDBSessionFactory")
    @Primary
    public SqlSessionFactory sqlSessionFactoryBean(@Qualifier("myProjectOneDataSource") DataSource dataSource) throws Exception {
        SqlSessionFactoryBean sqlSessionFactoryBean = new SqlSessionFactoryBean();
        //关键:mybatis文件的目录需要区分开来
        sqlSessionFactoryBean.setMapperLocations(new PathMatchingResourcePatternResolver().getResources("classpath:mybatis.myProjectOne/*.xml"));   //子模块中的类路径 mybatis.myProjectOne
        sqlSessionFactoryBean.setDataSource(dataSource);
        return sqlSessionFactoryBean.getObject();
    }

    @Bean(name = "myProjectOneTransactionManager")
    @Primary
    public DataSourceTransactionManager transactionManager(@Qualifier("myProjectOneDataSource") DataSource dataSource) {
        DataSourceTransactionManager transactionManager = new DataSourceTransactionManager();
        transactionManager.setDataSource(dataSource);
        return transactionManager;
    }

    @Bean(name = "myProjectOneTransactionTemplate")
    @Primary
    public TransactionTemplate transactionTemplate(@Qualifier("myProjectOneTransactionManager") DataSourceTransactionManager transactionManager) {
        TransactionTemplate transactionTemplate = new TransactionTemplate(transactionManager);
        return transactionTemplate;
    }
}
复制代码
主数据库配置,数据库的配置 以spring.datasource前缀,需要配置驱动程序名称。
spring.datasource.driver-class-name = com.mysql.jdbc.Driver
spring.datasource.url = jdbc:mysql://IP:3306/databaseName?useUnicode=true&characterEncoding=UTF8&zeroDateTimeBehavior=convertToNull&autoReconnect=true&allowMultiQueries=true&useSSL=false
spring.datasource.username = username
spring.datasource.password = password

主数据源

复制代码
import org.apache.ibatis.plugin.Interceptor;
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.autoconfigure.jdbc.DataSourceBuilder;
import org.springframework.boot.context.properties.ConfigurationProperties;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.core.io.support.PathMatchingResourcePatternResolver;

import javax.sql.DataSource;

/**
 * 数据源配置
 */
@Configuration
@MapperScan(basePackages = "com.my.projectTwo.mapper", sqlSessionFactoryRef = "myProjectTwodbSessionFactory")
public class TwoDBConfig {

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


    @Bean(name = "myProjectTwodbSessionFactory")
    public SqlSessionFactory sqlSessionFactoryBean(@Qualifier("myProjectTwodbDataSource") DataSource dataSource) throws Exception {
        SqlSessionFactoryBean sqlSessionFactoryBean = new SqlSessionFactoryBean();
        sqlSessionFactoryBean.setMapperLocations(new PathMatchingResourcePatternResolver().getResources("classpath:mybatis/*.xml"));
        sqlSessionFactoryBean.setDataSource(dataSource);
        sqlSessionFactoryBean.setPlugins(new Interceptor[]{new ResultDecryptSetInterceptor()});
        return sqlSessionFactoryBean.getObject();
    }
}
复制代码

 

posted on   oktokeep  阅读(50)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
历史上的今天:
2022-01-15 Excel表格Vlookup跨sheet取值,ISNA函数处理匹配不到的空字符串
2022-01-15 如何查询Windows10的激活时间等相关信息
< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

点击右上角即可分享
微信分享提示