一、配置文件
jdk環(huán)境:1.8 配置了雙數(shù)據(jù)源springboot+druid+pgsql,application.properties配置修改如下:
#當(dāng)前入庫主數(shù)據(jù)庫
spring.primary.datasource.type=com.alibaba.druid.pool.DruidDataSource
spring.primary.datasource.driver-class-name=org.postgresql.Driver
spring.primary.datasource.url=jdbc:postgresql://localhost:5432/testdb
spring.primary.datasource.username=postgres
spring.primary.datasource.password=postgres
#
#從數(shù)據(jù)庫
spring.secondary.datasource.type=com.alibaba.druid.pool.DruidDataSource
spring.secondary.datasource.driver-class-name=org.postgresql.Driver
spring.secondary.datasource.url=jdbc:postgresql://localhost:5432/postgres
spring.secondary.datasource.username=postgres
spring.secondary.datasource.password=postgres
spring.datasource.druid.initial-size=5
spring.datasource.druid.min-idle=5
spring.datasource.druid.max-active=20
二、Java代碼配置新增
主數(shù)據(jù)庫注入
/**
* @Author yang
* @Date 2023/2/20 11:10
* @Version 1.0
*/
import com.alibaba.druid.pool.DruidDataSource;
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.beans.factory.annotation.Value;
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 javax.sql.DataSource;
@Configuration
@MapperScan(basePackages = MasterDataSourceConfig.PACKAGE, sqlSessionFactoryRef = "masterSqlSessionFactory")
public class MasterDataSourceConfig {
// 精確到master目錄,以便跟其他數(shù)據(jù)源隔離
static final String PACKAGE = "com.xx.dao.master";
static final String MAPPER_LOCATION = "classpath*:com/xx/mapper/master/*.xml";
@Value("${spring.primary.datasource.url}")
private String url;
@Value("${spring.primary.datasource.username}")
private String user;
@Value("${spring.primary.datasource.password}")
private String password;
@Value("${spring.primary.datasource.driver-class-name}")
private String driverClass;
private SqlSessionFactory mSessionFactory;
@Bean(name = "masterDataSource")
@Primary
public DataSource masterDataSource() {
DruidDataSource dataSource = new DruidDataSource();
dataSource.setDriverClassName(driverClass);
dataSource.setUrl(url);
dataSource.setUsername(user);
dataSource.setPassword(password);
return dataSource;
}
@Bean(name = "masterTransactionManager")
@Primary
public DataSourceTransactionManager masterTransactionManager() {
return new DataSourceTransactionManager(masterDataSource());
}
@Bean(name = "masterSqlSessionFactory")
@Primary
public SqlSessionFactory masterSqlSessionFactory(@Qualifier("masterDataSource") DataSource masterDataSource)
throws Exception {
final SqlSessionFactoryBean sessionFactory = new SqlSessionFactoryBean();
sessionFactory.setDataSource(masterDataSource);
sessionFactory.setMapperLocations(new PathMatchingResourcePatternResolver()
.getResources(MasterDataSourceConfig.MAPPER_LOCATION));
//開啟駝峰
sessionFactory.getObject().getConfiguration().setMapUnderscoreToCamelCase(true);
this.mSessionFactory = sessionFactory.getObject();
return sessionFactory.getObject();
}
/**
* 獲取主庫 SessionFactory
* @return
*/
public SqlSessionFactory getMSessionFactory(){
return mSessionFactory;
}
}
從數(shù)據(jù)庫Java代碼:
/**
* @Author yang
* @Date 2023/2/20 11:52
* @Version 1.0
*/
@Configuration
// 掃描 Mapper 接口并容器管理
@MapperScan(basePackages = SecondDataSourceConfig.PACKAGE, sqlSessionFactoryRef = "secondSqlSessionFactory")
public class SecondDataSourceConfig {
//精確到第二個數(shù)據(jù)庫目錄,以便跟其他數(shù)據(jù)源隔離
static final String PACKAGE = "com.xx.dao.second";
static final String MAPPER_LOCATION = "classpath*:com/xx/mapper/second/*.xml";
@Value("${spring.secondary.datasource.url}")
private String url;
@Value("${spring.secondary.datasource.username}")
private String user;
@Value("${spring.secondary.datasource.password}")
private String password;
@Value("${spring.secondary.datasource.driver-class-name}")
private String driverClass;
@Bean(name = "secondDataSource")
public DataSource clusterDataSource() {
DruidDataSource dataSource = new DruidDataSource();
dataSource.setDriverClassName(driverClass);
dataSource.setUrl(url);
dataSource.setUsername(user);
dataSource.setPassword(password);
return dataSource;
}
@Bean(name = "secondTransactionManager")
public DataSourceTransactionManager clusterTransactionManager() {
return new DataSourceTransactionManager(clusterDataSource());
}
@Bean(name = "secondSqlSessionFactory")
public SqlSessionFactory clusterSqlSessionFactory(@Qualifier("secondDataSource") DataSource clusterDataSource)
throws Exception {
final SqlSessionFactoryBean sessionFactory = new SqlSessionFactoryBean();
sessionFactory.setDataSource(clusterDataSource);
sessionFactory.setMapperLocations(new PathMatchingResourcePatternResolver()
.getResources(SecondDataSourceConfig.MAPPER_LOCATION));
//開啟駝峰
sessionFactory.getObject().getConfiguration().setMapUnderscoreToCamelCase(true);
return sessionFactory.getObject();
}
}
三、mapper接口、mybatis/xml文件配置
? ? ?這里就就不一一貼代碼了,主要是接口對應(yīng)mybatis xml配置文件。項目文件接口如下:
創(chuàng)建成以上目錄就可以了,分別是dao接口、Java數(shù)據(jù)源配置、mybatis映射文件。
四、怎么使用
? ? ? 通過以上配置文件和代碼已經(jīng)對兩個數(shù)據(jù)源進行分割,直接正常使用訪問代碼即可,比如dao里面創(chuàng)建了testClass的操作
void insert(Test test); void delete(); Controller層我們通過@Autowired注解 使用就可以了。
這里需要注意修改:
@MapperScan里面的basePackages文章來源:http://www.zghlxwxcb.cn/news/detail-682267.html
MAPPER_LOCATION變量的配置,這里主要是不同的數(shù)據(jù)源配置掃描不同的mybatis配置文件文章來源地址http://www.zghlxwxcb.cn/news/detail-682267.html
到了這里,關(guān)于SpringBoot+mybatis+pgsql多個數(shù)據(jù)源配置的文章就介紹完了。如果您還想了解更多內(nèi)容,請在右上角搜索TOY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!