tk-mybatis整合springBoot使用兩個(gè)數(shù)據(jù)源的方法
根據(jù)項(xiàng)目功能需求,需要與第三方公共庫對接,需要對公共庫進(jìn)行相關(guān)操作,由于不想使用原生jdbc,所以采用mybaits進(jìn)行多數(shù)據(jù)配置。
單純的使用mybaits進(jìn)行多數(shù)據(jù)配置網(wǎng)上資料很多,但由于前期為了方便開發(fā),采用了tk-mybaits。關(guān)于tk-mybaits多數(shù)據(jù)源配置沒有相關(guān)材料,官方也沒有提供相關(guān)功能說明,所以最終采用mybatis+tk-mybaits分別使用的策略進(jìn)行多數(shù)據(jù)源配置功能實(shí)現(xiàn)。具體代碼如下
一、配置連接信息
#開發(fā)運(yùn)行環(huán)境數(shù)據(jù)庫 spring.datasource.local.url=jdbc:mysql://0.0.0.0:3306/zhdd spring.datasource.local.username=root spring.datasource.local.password= spring.datasource.local.driver-class-name=com.mysql.jdbc.Driver spring.datasource.local.druid.initial-size=1 spring.datasource.local.druid.min-idle=1 spring.datasource.local.druid.max-active=20 spring.datasource.local.druid.test-on-borrow=true spring.datasource.local.druid.stat-view-servlet.allow=true #第三方對接通用數(shù)據(jù)庫 spring.datasource.public.url=jdbc:mysql://0.0.0.0:3306/zhdd spring.datasource.public.username=root spring.datasource.public.password= spring.datasource.public.driver-class-name=com.mysql.jdbc.Driver spring.datasource.public.druid.initial-size=1 spring.datasource.public.druid.min-idle=1 spring.datasource.public.druid.max-active=20 spring.datasource.public.druid.test-on-borrow=true spring.datasource.public.druid.stat-view-servlet.allow=true
?二、配置DataSource數(shù)據(jù)源
?注意兩個(gè)數(shù)據(jù)源中有一個(gè)是為主數(shù)據(jù)源,需要增加一個(gè)@Primary注解,有且只能有一個(gè)需要。關(guān)于2個(gè)以上數(shù)據(jù)源沒有額外再進(jìn)行研究了,不過利用mybatis再額外配置多個(gè)數(shù)據(jù)源應(yīng)該可以實(shí)現(xiàn)
1.數(shù)據(jù)源1配置
package com.hiynn.core.mybatis;
import com.alibaba.druid.spring.boot.autoconfigure.DruidDataSourceBuilder;
import org.apache.ibatis.session.SqlSessionFactory;
import org.mybatis.spring.SqlSessionFactoryBean;
import org.springframework.beans.factory.annotation.Qualifier;
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 javax.sql.DataSource;
/**
* 開發(fā)運(yùn)行環(huán)境數(shù)據(jù)庫
*/
@Configuration
public class LocalDataSourceConfig {
@Bean(name = "localDataSource")
@ConfigurationProperties(prefix = "spring.datasource.local")
@Primary
public DataSource localDataSource() {
return DruidDataSourceBuilder.create().build();
}
@Bean(name = "localTransactionManager")
@Primary
public DataSourceTransactionManager mysqlTransactionManager() {
return new DataSourceTransactionManager(localDataSource());
}
@Bean(name = "localSqlSessionFactory")
@Primary
public SqlSessionFactory mysqlSqlSessionFactory(@Qualifier("localDataSource") DataSource dataSource)
throws Exception {
SqlSessionFactoryBean sessionFactory = new SqlSessionFactoryBean();
sessionFactory.setDataSource(dataSource);
//如果不使用xml的方式配置mapper,則可以省去下面這行mapper location的配置。
sessionFactory.setMapperLocations(new PathMatchingResourcePatternResolver()
.getResources("classpath*:mapper/*.xml"));
return sessionFactory.getObject();
}
}
2.數(shù)據(jù)源2配置
package com.hiynn.core.mybatis;
import com.alibaba.druid.spring.boot.autoconfigure.DruidDataSourceBuilder;
import org.apache.ibatis.session.SqlSessionFactory;
import org.mybatis.spring.SqlSessionFactoryBean;
import org.springframework.beans.factory.annotation.Qualifier;
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 org.springframework.jdbc.datasource.DataSourceTransactionManager;
import javax.sql.DataSource;
/**
* 公共通用數(shù)據(jù)庫
*/
@Configuration
public class PublicDataSourceConfig {
@Bean(name = "publicDataSource")
@ConfigurationProperties(prefix = "spring.datasource.public")
public DataSource publicDataSource() {
return DruidDataSourceBuilder.create().build();
}
@Bean(name = "publicTransactionManager")
public DataSourceTransactionManager mysqlTransactionManager() {
return new DataSourceTransactionManager(publicDataSource());
}
@Bean(name = "publicSqlSessionFactory")
public SqlSessionFactory mysqlSqlSessionFactory(@Qualifier("publicDataSource") DataSource dataSource)
throws Exception {
SqlSessionFactoryBean sessionFactory = new SqlSessionFactoryBean();
sessionFactory.setDataSource(dataSource);
//如果不使用xml的方式配置mapper,則可以省去下面這行mapper location的配置。
sessionFactory.setMapperLocations(new PathMatchingResourcePatternResolver()
.getResources("classpath*:mapper2/*.xml"));
return sessionFactory.getObject();
}
}
三、Application配置
package com.hiynn.core;
//特別注意,下面的是 tk.MapperScan
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.boot.web.servlet.ServletComponentScan;
import org.springframework.boot.web.servlet.support.SpringBootServletInitializer;
import org.springframework.transaction.annotation.EnableTransactionManagement;
import springfox.documentation.swagger2.annotations.EnableSwagger2;
import tk.mybatis.spring.annotation.MapperScan;
/**
* @author zz
* @date 2018-7-2
*/
@ServletComponentScan
@SpringBootApplication
@EnableTransactionManagement
@EnableSwagger2
@MapperScan(basePackages = "com.hiynn.core.**.mapper",sqlSessionFactoryRef = "localSqlSessionFactory")
@org.mybatis.spring.annotation.MapperScan(basePackages = "com.hiynn.core.**.mapper2",sqlSessionFactoryRef = "publicSqlSessionFactory")
public class Application extends SpringBootServletInitializer{
public static void main(String[] args) {
SpringApplication.run(Application.class, args);
}
}
四、Mapper代碼結(jié)構(gòu)

補(bǔ)充:
一、解決mybatis數(shù)據(jù)庫駝峰命名自動映射問題以及sql語句打印問題,通過讀取配置文件實(shí)現(xiàn)。兩個(gè)數(shù)據(jù)源都需要設(shè)置
@Bean(name = "localSqlSessionFactory")
@Primary
public SqlSessionFactory mysqlSqlSessionFactory(@Qualifier("localDataSource") DataSource dataSource)
throws Exception {
SqlSessionFactoryBean sessionFactory = new SqlSessionFactoryBean();
sessionFactory.setDataSource(dataSource);
//添加mybatis配置文件讀取功能更
sessionFactory.setConfigLocation(new PathMatchingResourcePatternResolver().getResource("mybatis-config.xml"));
//如果不使用xml的方式配置mapper,則可以省去下面這行mapper location的配置。
sessionFactory.setMapperLocations(new PathMatchingResourcePatternResolver()
.getResources("classpath*:mapper/*.xml"));
return sessionFactory.getObject();
}
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE configuration PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>
<settings>
<setting name="mapUnderscoreToCamelCase" value="true" />
<!-- 打印查詢語句 -->
<setting name="logImpl" value="STDOUT_LOGGING" />
</settings>
</configuration>
二、配置PageHelper分頁插件,在application.properties統(tǒng)一配置
數(shù)據(jù)庫方言 指定分頁插件使用哪種數(shù)據(jù)庫方言 pagehelper.helperDialect=mysql #分頁參數(shù)合理化 pageNum<=0 時(shí)會查詢第一頁, pageNum>pages(超過總數(shù)時(shí)),會查詢最后一頁 pagehelper.reasonable=true pagehelper.supportMethodsArguments=true pagehelper.params=count=countSql
到此這篇關(guān)于tk-mybatis整合springBoot使用兩個(gè)數(shù)據(jù)源的方法的文章就介紹到這了,更多相關(guān)tk-mybatis springBoot數(shù)據(jù)源內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Spring Boot中@ConditionalOnProperty的使用方法
這篇文章主要給大家介紹了關(guān)于Spring Boot中@ConditionalOnProperty的使用方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者使用Spring Boot具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧2019-12-12
spring data jpa如何只查詢實(shí)體部分字段
這篇文章主要介紹了spring data jpa如何只查詢實(shí)體部分字段的操作,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-06-06
Java實(shí)現(xiàn)的質(zhì)因數(shù)分解操作示例【基于遞歸算法】
這篇文章主要介紹了Java實(shí)現(xiàn)的質(zhì)因數(shù)分解操作,結(jié)合實(shí)例形式較為詳細(xì)的分析了Java基于遞歸算法實(shí)現(xiàn)針對整數(shù)的質(zhì)因數(shù)分解相關(guān)操作技巧,需要的朋友可以參考下2018-03-03
什么情況下會出現(xiàn)java.io.IOException?:?Broken?pipe這個(gè)錯(cuò)誤以及解決辦法
這篇文章主要介紹了什么情況下會出現(xiàn)java.io.IOException?:?Broken?pipe這個(gè)錯(cuò)誤以及解決辦法的相關(guān)資料,這個(gè)錯(cuò)誤表示通信另一端已關(guān)閉連接,常發(fā)生在客戶端關(guān)閉連接、網(wǎng)絡(luò)超時(shí)或資源不足等情況,文中將解決辦法介紹的非常詳細(xì),需要的朋友可以參考下2024-10-10

