SpringBoot如何配置MySQL和Oracl雙數(shù)據源(Mybatis)
一、前言
目前SpringBoot的版本已經是2.2.2了,2.0以后的版本就已經默認使用hikari作為連接池了。
因此整合hikari也變得十分簡單了,下面介紹一下在2.0以后的SpringBoot版本中如何配置一Mysql數(shù)據源和Oracle數(shù)據源。
二、配置文件
application.yml文件
如下
spring: datasource: #數(shù)據源 hikari: # 第一個Mysql數(shù)據源配置 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已經換新的啦 # driverClassName: com.mysql.jdbc.Driver driverClassName: com.mysql.cj.jdbc.Driver type: com.zaxxer.hikari.HikariDataSource # 連接池中維護的最小空閑連接數(shù) minimum-idle: 5 # 配置最大池大小 maximum-pool-size: 15 # 配置從池返回的連接的默認自動提交行為。默認值為true。 auto-commit: true # 允許連接在連接池中空閑的最長時間(以毫秒為單位) idle-timeout: 30000 # 連接池的用戶定義名稱,主要出現(xiàn)在日志記錄和JMX管理控制臺中以識別池和池配置 pool-name: HikariDataPool # 池中連接關閉后的最長生命周期(以毫秒為單位) max-lifetime: 1800000 # 客戶端等待連接池連接的最大毫秒數(shù) connection-timeout: 30000 # 測試連接 connection-test-query: select 1 from dual # 第二個Oracle數(shù)據源 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ù)據源配置類
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ù)據源配置類
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); } }
三、主要注意點
@MapperScan(basePackages = “com.zlc.springcloud.repository.*.coresystem”, sqlSessionFactoryRef = “coreSqlSessionFactory”)
這個是設置Repository所在的位置,代表repository包下的所有coresystem包下的所有文件
@ConfigurationProperties(prefix = “spring.datasource.hikari.core”)
這里是讀取application.yml文件中core節(jié)點下的所有東西,一定要對應行,如果自己取了別的名字,記得更換一下
Mybatis的xml文件位置要配置一下,和自己的對應
//xml位置 sqlSessionFactoryBean.setMapperLocations(new PathMatchingResourcePatternResolver().getResources("classpath:/mapper/**/coresystem/*.xml"));
總結
以上就是最需要注意的地方,移植的時候注意對應上。
這些僅為個人經驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
SpringBoot如何實現(xiàn)各種參數(shù)校驗
文章詳細介紹了SpringValidation的使用,包括簡單使用、requestBody參數(shù)校驗、requestParam/PathVariable參數(shù)校驗、統(tǒng)一異常處理、分組校驗、嵌套校驗、集合校驗、自定義校驗、編程式校驗、快速失敗、@Valid和@Validated的區(qū)別以及實現(xiàn)原理2024-12-12Java中執(zhí)行docker命令的實現(xiàn)示例
本文主要介紹了Java中執(zhí)行docker命令的實現(xiàn)示例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2023-08-08SpringBoot使用Logback進行日志記錄的代碼示例
在開發(fā)Web應用程序時,日志記錄是非常重要的一部分,在SpringBoot中,我們可以使用Logback進行日志記錄,Logback是一款高性能、靈活的日志框架,它可以滿足各種不同的日志需求,在本文中,我們介紹了如何在SpringBoot中使用Logback進行日志記錄2023-06-06