springboot 配置pg多数据源

application.yaml配置

server:
  port: 3038

spring:
  datasource:
    learningdb: 
      jdbcUrl: jdbc:postgresql://localhost:5432/数据库名
      driverClassName: org.postgresql.Driver
      username: username
      password: password
    userdb: 
      jdbcUrl: jdbc:postgresql://localhost:5432/数据库名
      driverClassName: org.postgresql.Driver
      username: username
      password: password

配置类:PgLearningDataSourceConfig


package com.deltaww.dkam.scheduler.config;

import javax.sql.DataSource;

import org.apache.ibatis.session.SqlSessionFactory;
import org.mybatis.spring.SqlSessionFactoryBean;
import org.mybatis.spring.SqlSessionTemplate;
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.core.io.support.PathMatchingResourcePatternResolver;

@Configuration
@MapperScan(basePackages = "com.deltaww.dkam.scheduler.repository.pg.mapper.learning", sqlSessionFactoryRef = "pgLearningSqlSessionFactory")
public class PgLearningDataSourceConfig {
	
    @Bean(name = "pgLearningDataSource")
    @ConfigurationProperties("spring.datasource.learningdb")
    public DataSource dbDataSource() {
        return DataSourceBuilder.create().build();
    }

    @Bean(name = "pgLearningSqlSessionFactory")
    public SqlSessionFactory sqlSessionFactory(@Qualifier("pgLearningDataSource") DataSource dataSource) throws Exception {
        SqlSessionFactoryBean sessionFactoryBean = new SqlSessionFactoryBean();
        sessionFactoryBean.setDataSource(dataSource);
        sessionFactoryBean.setMapperLocations(new PathMatchingResourcePatternResolver().
                getResources("classpath*:com/deltaww/dkam/learning/mapper/*Mapper.xml"));
        return sessionFactoryBean.getObject();
    }
    
    @Bean("pgLearningSqlSessionTemplate")
    public SqlSessionTemplate learningSqlSessionTemplate(@Qualifier("pgLearningSqlSessionFactory") SqlSessionFactory sqlSessionFactory){
        return new SqlSessionTemplate(sqlSessionFactory);
    }
    
}

package com.deltaww.dkam.scheduler.config;

import javax.sql.DataSource;

import org.apache.ibatis.session.SqlSessionFactory;
import org.mybatis.spring.SqlSessionFactoryBean;
import org.mybatis.spring.SqlSessionTemplate;
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.core.io.support.PathMatchingResourcePatternResolver;


@Configuration
@MapperScan(basePackages = "com.deltaww.dkam.scheduler.repository.pg.mapper.user", sqlSessionFactoryRef = "pgUserSqlSessionFactory")
public class PgUserDataSourceConfig {
 
    @Bean(name = "pgUserDataSource")
    @ConfigurationProperties("spring.datasource.userdb")
    public DataSource dbDataSource() {
        return DataSourceBuilder.create().build();
    }

    @Bean(name = "pgUserSqlSessionFactory")
    public SqlSessionFactory sqlSessionFactory(@Qualifier("pgUserDataSource") DataSource dataSource) throws Exception {
        SqlSessionFactoryBean sessionFactoryBean = new SqlSessionFactoryBean();
        sessionFactoryBean.setDataSource(dataSource);
        sessionFactoryBean.setMapperLocations(new PathMatchingResourcePatternResolver().
                getResources("classpath*:com/deltaww/dkam/user/mapper/*Mapper.xml"));
        return sessionFactoryBean.getObject();
    }
    
    @Bean("pgUserSqlSessionTemplate")
    public SqlSessionTemplate userSqlSessionTemplate(@Qualifier("pgUserSqlSessionFactory") SqlSessionFactory sqlSessionFactory){
        return new SqlSessionTemplate(sqlSessionFactory);
    }
    
}

 

多数据源直接往后加就完事了
 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值