SpringBoot如何配置MySQL和Oracl雙數(shù)據(jù)源(Mybatis)
一、前言
目前SpringBoot的版本已經(jīng)是2.2.2了,2.0以后的版本就已經(jīng)默認(rèn)使用hikari作為連接池了。
因此整合hikari也變得十分簡(jiǎn)單了,下面介紹一下在2.0以后的SpringBoot版本中如何配置一Mysql數(shù)據(jù)源和Oracle數(shù)據(jù)源。
二、配置文件
application.yml文件
如下
spring:
datasource: #數(shù)據(jù)源
hikari:
# 第一個(gè)Mysql數(shù)據(jù)源配置
master:
jdbc-url: jdbc:mysql://127.0.0.1:3306/test1?characterEncoding=UTF-8&serverTimezone=UTC&useSSL=false&allowPublicKeyRetrieval=true
username: root
password: 123456
# Spring Boot已經(jīng)換新的啦
# driverClassName: com.mysql.jdbc.Driver
driverClassName: com.mysql.cj.jdbc.Driver
type: com.zaxxer.hikari.HikariDataSource
# 連接池中維護(hù)的最小空閑連接數(shù)
minimum-idle: 5
# 配置最大池大小
maximum-pool-size: 15
# 配置從池返回的連接的默認(rèn)自動(dòng)提交行為。默認(rèn)值為true。
auto-commit: true
# 允許連接在連接池中空閑的最長(zhǎng)時(shí)間(以毫秒為單位)
idle-timeout: 30000
# 連接池的用戶定義名稱,主要出現(xiàn)在日志記錄和JMX管理控制臺(tái)中以識(shí)別池和池配置
pool-name: HikariDataPool
# 池中連接關(guān)閉后的最長(zhǎng)生命周期(以毫秒為單位)
max-lifetime: 1800000
# 客戶端等待連接池連接的最大毫秒數(shù)
connection-timeout: 30000
# 測(cè)試連接
connection-test-query: select 1 from dual
# 第二個(gè)Oracle數(shù)據(jù)源
core:
jdbc-url: jdbc:oracle:thin:@127.0.0.1:1521:test2
username: root
password: 123456
driverClassName: oracle.jdbc.OracleDriver
type: com.zaxxer.hikari.HikariDataSource
minimum-idle: 5
maximum-pool-size: 15
max-lifetime: 1800000
idle-timeout: 30000
connection-timeout: 30000
pool-name: HikariDataPoolOracle
connection-test-query: select 1 from dual
三、配置類
1)Oracle數(shù)據(jù)源配置類
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;
import javax.sql.DataSource;
@Configuration
@MapperScan(basePackages = "com.zlc.springcloud.repository.*.coresystem", sqlSessionFactoryRef = "coreSqlSessionFactory")
public class CoreDataSourceConfig {
@Bean(name = "coreDataSource")
@ConfigurationProperties(prefix = "spring.datasource.hikari.core")
public DataSource getCoreDataSource() {
return DataSourceBuilder.create().build();
}
@Bean(name = "coreSqlSessionFactory")
public SqlSessionFactory coreSqlSessionFactory(@Qualifier("coreDataSource") DataSource dataSource) throws Exception {
SqlSessionFactoryBean sqlSessionFactoryBean=new SqlSessionFactoryBean();
sqlSessionFactoryBean.setDataSource(dataSource);
//xml位置
sqlSessionFactoryBean.setMapperLocations(new PathMatchingResourcePatternResolver().getResources("classpath:/mapper/**/coresystem/*.xml"));
return sqlSessionFactoryBean.getObject();
}
@Bean(name = "coreSqlSessionTemplate")
public SqlSessionTemplate coreSqlSessionTemplate(@Qualifier("coreSqlSessionFactory") SqlSessionFactory sqlSessionFactory){
return new SqlSessionTemplate(sqlSessionFactory);
}
}
2)Mysql數(shù)據(jù)源配置類
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.context.annotation.Primary;
import org.springframework.core.io.support.PathMatchingResourcePatternResolver;
import org.springframework.jdbc.datasource.DataSourceTransactionManager;
import javax.sql.DataSource;
@Configuration
@MapperScan(basePackages = "com.zlc.springcloud.repository.*.master", sqlSessionFactoryRef = "masterSqlSessionFactory")
public class MasterDataSourceConfig {
@Bean(name = "masterDataSource")
@ConfigurationProperties(prefix = "spring.datasource.hikari.master")
public DataSource getMasterDataSource() {
return DataSourceBuilder.create().build();
}
@Bean(name = "masterSqlSessionFactory")
public SqlSessionFactory masterSqlSessionFactory(@Qualifier("masterDataSource") DataSource dataSource) throws Exception {
SqlSessionFactoryBean sqlSessionFactoryBean=new SqlSessionFactoryBean();
sqlSessionFactoryBean.setDataSource(dataSource);
//xml位置
sqlSessionFactoryBean.setMapperLocations(new PathMatchingResourcePatternResolver().getResources("classpath:/mapper/**/master/*.xml"));
return sqlSessionFactoryBean.getObject();
}
@Bean(name = "masterSqlSessionTemplate")
public SqlSessionTemplate masterSqlSessionTemplate(@Qualifier("masterSqlSessionFactory") SqlSessionFactory sqlSessionFactory){
return new SqlSessionTemplate(sqlSessionFactory);
}
@Bean(name = "MasterTransactionManager")
public DataSourceTransactionManager transactionManager(@Qualifier("masterDataSource")DataSource dataSource) {
return new DataSourceTransactionManager(dataSource);
}
}
三、主要注意點(diǎn)
@MapperScan(basePackages = “com.zlc.springcloud.repository.*.coresystem”, sqlSessionFactoryRef = “coreSqlSessionFactory”)
這個(gè)是設(shè)置Repository所在的位置,代表repository包下的所有coresystem包下的所有文件

@ConfigurationProperties(prefix = “spring.datasource.hikari.core”)
這里是讀取application.yml文件中core節(jié)點(diǎn)下的所有東西,一定要對(duì)應(yīng)行,如果自己取了別的名字,記得更換一下
Mybatis的xml文件位置要配置一下,和自己的對(duì)應(yīng)
//xml位置
sqlSessionFactoryBean.setMapperLocations(new PathMatchingResourcePatternResolver().getResources("classpath:/mapper/**/coresystem/*.xml"));
總結(jié)
以上就是最需要注意的地方,移植的時(shí)候注意對(duì)應(yīng)上。
這些僅為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
SpringBoot如何實(shí)現(xiàn)各種參數(shù)校驗(yàn)
文章詳細(xì)介紹了SpringValidation的使用,包括簡(jiǎn)單使用、requestBody參數(shù)校驗(yàn)、requestParam/PathVariable參數(shù)校驗(yàn)、統(tǒng)一異常處理、分組校驗(yàn)、嵌套校驗(yàn)、集合校驗(yàn)、自定義校驗(yàn)、編程式校驗(yàn)、快速失敗、@Valid和@Validated的區(qū)別以及實(shí)現(xiàn)原理2024-12-12
Java中執(zhí)行docker命令的實(shí)現(xiàn)示例
本文主要介紹了Java中執(zhí)行docker命令的實(shí)現(xiàn)示例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2023-08-08
SpringBoot使用Logback進(jìn)行日志記錄的代碼示例
在開(kāi)發(fā)Web應(yīng)用程序時(shí),日志記錄是非常重要的一部分,在SpringBoot中,我們可以使用Logback進(jìn)行日志記錄,Logback是一款高性能、靈活的日志框架,它可以滿足各種不同的日志需求,在本文中,我們介紹了如何在SpringBoot中使用Logback進(jìn)行日志記錄2023-06-06
Java程序員必須知道的5個(gè)JVM命令行標(biāo)志
這篇文章主要介紹了每個(gè)Java程序員必須知道的5個(gè)JVM命令行標(biāo)志,需要的朋友可以參考下2015-03-03
利用Java實(shí)現(xiàn)玩家打怪小游戲的完整過(guò)程
這篇文章主要介紹了如何使用Java創(chuàng)建一個(gè)簡(jiǎn)單的“打怪小游戲”,游戲中的角色分為法師、戰(zhàn)士、BOSS和一個(gè)Team類,代碼展示了如何通過(guò)面向?qū)ο缶幊虂?lái)實(shí)現(xiàn)一個(gè)基本的戰(zhàn)斗系統(tǒng),需要的朋友可以參考下2024-12-12

