tk-mybatis整合springBoot使用兩個(gè)數(shù)據(jù)源的方法
根據(jù)項(xiàng)目功能需求,需要與第三方公共庫(kù)對(duì)接,需要對(duì)公共庫(kù)進(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ù)庫(kù) 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 #第三方對(duì)接通用數(shù)據(jù)庫(kù) 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ù)庫(kù) */ @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ù)庫(kù) */ @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ù)庫(kù)駝峰命名自動(dòng)映射問題以及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分頁(yè)插件,在application.properties統(tǒng)一配置
數(shù)據(jù)庫(kù)方言 指定分頁(yè)插件使用哪種數(shù)據(jù)庫(kù)方言 pagehelper.helperDialect=mysql #分頁(yè)參數(shù)合理化 pageNum<=0 時(shí)會(huì)查詢第一頁(yè), pageNum>pages(超過總數(shù)時(shí)),會(huì)查詢最后一頁(yè) 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)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
淺談java中集合的由來,以及集合和數(shù)組的區(qū)別詳解
下面小編就為大家?guī)硪黄獪\談java中集合的由來,以及集合和數(shù)組的區(qū)別詳解。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2016-10-10Spring 定時(shí)任務(wù)@Scheduled 注解中的 Cron 表達(dá)式詳解
Cron 表達(dá)式是一種用于定義定時(shí)任務(wù)觸發(fā)時(shí)間的字符串表示形式,它由七個(gè)字段組成,分別表示秒、分鐘、小時(shí)、日期、月份、星期和年份,這篇文章主要介紹了Spring 定時(shí)任務(wù)@Scheduled 注解中的 Cron 表達(dá)式,需要的朋友可以參考下2023-07-07Spring Boot Shiro在Web應(yīng)用中的作用詳解
這篇文章主要為大家介紹了Spring Boot Shiro在Web應(yīng)用中的作用詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-02-02Java實(shí)現(xiàn)對(duì)一行英文進(jìn)行單詞提取功能示例
這篇文章主要介紹了Java實(shí)現(xiàn)對(duì)一行英文進(jìn)行單詞提取功能,結(jié)合實(shí)例形式分析了java基于StringTokenizer類進(jìn)行字符串分割的相關(guān)操作技巧,需要的朋友可以參考下2017-10-10Java 用反射設(shè)置對(duì)象的屬性值實(shí)例詳解
這篇文章主要介紹了Java 用反射設(shè)置對(duì)象的屬性值實(shí)例詳解的相關(guān)資料,需要的朋友可以參考下2017-05-05springboot項(xiàng)目啟動(dòng)的時(shí)候參數(shù)無效的解決
這篇文章主要介紹了springboot項(xiàng)目啟動(dòng)的時(shí)候參數(shù)無效的解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-09-09Java File類的簡(jiǎn)單使用教程(創(chuàng)建、刪除、遍歷與判斷是否存在等)
這篇文章主要給大家介紹了關(guān)于Java File類的簡(jiǎn)單使用(創(chuàng)建、刪除、遍歷與判斷是否存在等)的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-12-12spring基礎(chǔ)系列之JavaConfig配置詳解
本篇文章主要介紹了spring基礎(chǔ)系列之JavaConfig配置詳解,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-07-07