SpringBoot +MybatisPlus集成多數(shù)據(jù)源的使用案例
引言
應項目需求,需要引入另外的Mysql數(shù)據(jù)庫,但是項目已經(jīng)引入一個Mysql,這時有幾種方案
- 通過Dynamic-DataSource 框架,無縫集成 但是是動態(tài)切換數(shù)據(jù)源的,跟項目需求不符合,于是采取第二種
- 通過自定義數(shù)據(jù)源配置類,無縫引入多個數(shù)據(jù)源,并且基于文件目錄隔離
步驟
引入依賴
項目需要引入了MyBatis Plus即可,無需引入額外依賴
<dependency>
<groupId>com.baomidou</groupId>
<artifactId>mybatis-plus-boot-starter</artifactId>
<version>3.5.12</version>
</dependency>修改配置文件
spring:
datasource:
d1:
password: xxxx
username: xxxx
jdbc-url: jdbc:mysql://xxxx:3306/ecshop_wp?characterEncoding=utf-8&useSSL=false&serverTimezone=Asia/Shanghai&allowPublicKeyRetrieval=true
driver-class-name: com.mysql.cj.jdbc.Driver
d2:
password: root
username: root
jdbc-url: jdbc:mysql://127.0.0.1:3306/xg_bi_lcc?characterEncoding=utf-8&useSSL=false&serverTimezone=Asia/Shanghai&allowPublicKeyRetrieval=true
driver-class-name: com.mysql.cj.jdbc.Driver添加配置類
@Configuration
@MapperScan(basePackages = "xg.xx.model.front.service.mysql.mapper1", sqlSessionFactoryRef = "d1SqlSessionFactory")
public class EcshopWpDataSourceConfig {
@Bean(name = "d1DataSource")
@ConfigurationProperties(prefix = "spring.datasource.d1")
public DataSource ecshopWpDataSource() {
return DataSourceBuilder.create().build();
}
@Bean(name = "d1SqlSessionFactory")
public SqlSessionFactory ecshopWpSqlSessionFactory(@Qualifier("d1DataSource") DataSource dataSource) throws Exception {
MybatisSqlSessionFactoryBean bean = new MybatisSqlSessionFactoryBean();
//configuration配置bean
//MybatisConfiguration configuration = new MybatisConfiguration();
//configuration.setMapUnderscoreToCamelCase(true);
//configuration.setCacheEnabled(false);
// 配置打印sql語句s
//configuration.setLogImpl(StdOutImpl.class);
// 添加自定義SQL注入
//bean.setConfiguration(configuration);
//插件對象
MybatisPlusInterceptor mybatisPlusInterceptor = new MybatisPlusInterceptor();
//動態(tài)表名
//DynamicTableNameInnerInterceptor dynamicTableNameInnerInterceptor = new DynamicTableNameInnerInterceptor();
//可以傳多個表名參數(shù),指定哪些表使用MonthTableNameHandler處理表名稱
//dynamicTableNameInnerInterceptor.setTableNameHandler(new MonthTableNameHandler("t_table_name"));
//以攔截器的方式處理表名稱
//可以傳遞多個攔截器,即:可以傳遞多個表名處理器TableNameHandler
//mybatisPlusInterceptor.addInnerInterceptor(dynamicTableNameInnerInterceptor);
//分頁插件
mybatisPlusInterceptor.addInnerInterceptor(new PaginationInnerInterceptor(DbType.MYSQL));
bean.setDataSource(dataSource);
// 設置mybatis的xml所在位置
bean.setMapperLocations(new PathMatchingResourcePatternResolver().getResources("classpath*:mybatis/d1/*.xml"));
bean.setPlugins(mybatisPlusInterceptor);
return bean.getObject();
}
@Bean(name = "d1TransactionManager")
public DataSourceTransactionManager ecshopWpTransactionManager(@Qualifier("d1DataSource") DataSource dataSource) {
return new DataSourceTransactionManager(dataSource);
}
}@Configuration
@MapperScan(basePackages = "xg.xx.model.front.service.mysql.Mapper2", sqlSessionFactoryRef = "d2SqlSessionFactory")
public class XgBiLccDataSourceConfig {
@Bean(name = "d2DataSource")
@ConfigurationProperties(prefix = "spring.datasource.d2")
public DataSource ecshopWpDataSource() {
return DataSourceBuilder.create().build();
}
@Bean(name = "d2SqlSessionFactory")
public SqlSessionFactory ecshopWpSqlSessionFactory(@Qualifier("d2DataSource") DataSource dataSource) throws Exception {
MybatisSqlSessionFactoryBean bean = new MybatisSqlSessionFactoryBean();
//configuration配置bean
//MybatisConfiguration configuration = new MybatisConfiguration();
//configuration.setMapUnderscoreToCamelCase(true);
//configuration.setCacheEnabled(false);
// 配置打印sql語句s
//configuration.setLogImpl(StdOutImpl.class);
// 添加自定義SQL注入
//bean.setConfiguration(configuration);
//插件對象
MybatisPlusInterceptor mybatisPlusInterceptor = new MybatisPlusInterceptor();
//動態(tài)表名
//DynamicTableNameInnerInterceptor dynamicTableNameInnerInterceptor = new DynamicTableNameInnerInterceptor();
//可以傳多個表名參數(shù),指定哪些表使用MonthTableNameHandler處理表名稱
//dynamicTableNameInnerInterceptor.setTableNameHandler(new MonthTableNameHandler("t_table_name"));
//以攔截器的方式處理表名稱
//可以傳遞多個攔截器,即:可以傳遞多個表名處理器TableNameHandler
//mybatisPlusInterceptor.addInnerInterceptor(dynamicTableNameInnerInterceptor);
//分頁插件
mybatisPlusInterceptor.addInnerInterceptor(new PaginationInnerInterceptor(DbType.MYSQL));
bean.setDataSource(dataSource);
// 設置mybatis的xml所在位置
bean.setMapperLocations(new PathMatchingResourcePatternResolver().getResources("classpath*:mybatis/d2/*.xml"));
bean.setPlugins(mybatisPlusInterceptor);
return bean.getObject();
}
@Bean(name = "d2TransactionManager")
public DataSourceTransactionManager ecshopWpTransactionManager(@Qualifier("d2DataSource") DataSource dataSource) {
return new DataSourceTransactionManager(dataSource);
}
}使用案例
@Transactional
@Transactional(value = "d2TransactionManager", rollbackFor = Exception.class) 這樣即可進行全局事物管理
到此這篇關(guān)于SpringBoot +MybatisPlus集成多數(shù)據(jù)源的文章就介紹到這了,更多相關(guān)SpringBoot MybatisPlus多數(shù)據(jù)源內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- SpringBoot+MybatisPlus+jdbc連接池配置多數(shù)據(jù)源的實現(xiàn)
- springboot集成mybatisPlus+多數(shù)據(jù)源的實現(xiàn)示例
- SpringBoot3.0集成MybatisPlus的實現(xiàn)方法
- SpringBoot連接PostgreSQL+MybatisPlus入門案例(代碼詳解)
- SpringBoot項目整合MybatisPlus并使用SQLite作為數(shù)據(jù)庫的過程
- SpringBoot整合MybatisPlus的基本應用詳解
- SpringBoot整合MybatisPlus的簡單教程實現(xiàn)(簡單整合)
相關(guān)文章
Spring?Lifecycle?和?SmartLifecycle區(qū)別面試精講
這篇文章主要為大家介紹了Spring?Lifecycle和SmartLifecycle的區(qū)別面試精講,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-10-10
Java使用Soap方式調(diào)用WebService接口代碼示例
Java調(diào)用WebService接口是指通過Java語言來訪問并與WebService進行交互,WebService是一種基于Web的服務架構(gòu),它通過標準的XML和HTTP協(xié)議來提供服務,這篇文章主要給大家介紹了關(guān)于Java使用Soap方式調(diào)用WebService接口的相關(guān)資料,需要的朋友可以參考下2024-03-03
Java實現(xiàn)JSON與XML相互轉(zhuǎn)換的簡明教程
Java實現(xiàn)復雜數(shù)據(jù)結(jié)構(gòu)(如嵌套對象、數(shù)組)在 JSON 與 XML 之間的相互轉(zhuǎn)換,可以使用 Jackson 和 Jackson XML 擴展庫來完成,Jackson 是一個流行的 JSON 處理庫,通過 Jackson 的 XML 擴展庫,可以實現(xiàn) JSON 和 XML 之間的轉(zhuǎn)換,需要的朋友可以參考下2024-08-08
IntelliJ IDEA修改新建文件自動生成注釋的user名
今天小編就為大家分享一篇關(guān)于IntelliJ IDEA修改新建文件自動生成注釋的user名,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧2018-10-10

