日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

springboot2+mybatis多種方式實現多數據配置方法

瀏覽:28日期:2023-11-26 18:06:05

業務系統復雜程度增加,為了解決數據庫I/O瓶頸,很自然會進行拆庫拆表分服務來應對。這就會出現一個系統中可能會訪問多處數據庫,需要配置多個數據源。

第一種場景:項目服務從其它多處數據庫取基礎數據進行業務處理,因此各庫之間不會出現重表等情況。

第二種場景:為了減輕寫入壓力進行讀寫分庫,讀走從庫,寫為主庫。此種表名等信息皆為一致。

第三種場景:以上兩種皆有。對于某些業務需要大數據量的匯總統計,希望不影響正常業務必須走從庫(表信息一致),某些配置信息不存在讀寫壓力,出現不分庫(表信息不一致)

項目源代碼:

https://github.com/zzsong/springboot-multiple-datasource.git

有三個目錄:

one: 直接使用多@Bean配置,@MapperScan來路徑區分讀何庫

two: 使用注解的方式來標識走何dataSource,AOP攔截注入動態數據源

third: 使用spring的Bean命名策略進行區分數據來源

項目技術選型: springBoot2.2.5 + mybatis + druid + mysql

先看主要的pom包

<parent> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-parent</artifactId> <version>2.2.5.RELEASE</version> <relativePath/> </parent><dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-jdbc</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-jdbc</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-aop</artifactId> </dependency> <dependency> <groupId>org.mybatis.spring.boot</groupId> <artifactId>mybatis-spring-boot-starter</artifactId> <version>2.1.2</version> </dependency> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <version>8.0.19</version> </dependency> <dependency> <groupId>com.alibaba</groupId> <artifactId>druid-spring-boot-starter</artifactId> <version>1.1.21</version> </dependency>

application.yml

spring: datasource: druid: core: url: jdbc:mysql:///kc_core?characterEncoding=utf-8&serverTimezone=Asia/Shanghai username: root password: 123456 driver-class-name: com.mysql.cj.jdbc.Driver type: com.alibaba.druid.pool.DruidDataSource schedule: url: jdbc:mysql:///kc_schedule?characterEncoding=utf-8&serverTimezone=Asia/Shanghai username: root password: 123456 driver-class-name: com.mysql.cj.jdbc.Driver type: com.alibaba.druid.pool.DruidDataSource

mysql新版本必須帶有serverTimezone,不然會報連接異常。

第一種:通過@MapperScans 掃描匹配相關的數據源

@Configuration@MapperScans({ @MapperScan(basePackages = 'com.zss.one.mapper.core', sqlSessionTemplateRef = 'coreSqlSessionTemplate',sqlSessionFactoryRef = 'coreSqlSessionFactory'), @MapperScan(basePackages = 'com.zss.one.mapper.schedule', sqlSessionTemplateRef = 'scheduleSqlSessionTemplate',sqlSessionFactoryRef = 'scheduleSqlSessionFactory')})public class MybatisOneConfig { @Bean @ConfigurationProperties(prefix = 'spring.datasource.druid.core') public DataSource coreDataSource(){ return DruidDataSourceBuilder.create().build(); } @Bean public SqlSessionFactory coreSqlSessionFactory(@Qualifier('coreDataSource') DataSource coreDataSource) throws Exception { SqlSessionFactoryBean sessionFactory = new SqlSessionFactoryBean(); sessionFactory.setDataSource(coreDataSource); sessionFactory.getObject().getConfiguration().setJdbcTypeForNull(null); sessionFactory.getObject().getConfiguration().setMapUnderscoreToCamelCase(true); return sessionFactory.getObject(); } @Bean public SqlSessionTemplate coreSqlSessionTemplate(@Qualifier('coreSqlSessionFactory') SqlSessionFactory sqlSessionFactory) throws Exception { return new SqlSessionTemplate(sqlSessionFactory); } //======schedule======== @Bean @ConfigurationProperties(prefix = 'spring.datasource.druid.schedule') public DataSource scheduleDataSource(){ return DruidDataSourceBuilder.create().build(); } @Bean public SqlSessionFactory scheduleSqlSessionFactory(@Qualifier('scheduleDataSource') DataSource coreDataSource) throws Exception { SqlSessionFactoryBean sessionFactory = new SqlSessionFactoryBean(); sessionFactory.setDataSource(coreDataSource); sessionFactory.getObject().getConfiguration().setJdbcTypeForNull(null); sessionFactory.getObject().getConfiguration().setMapUnderscoreToCamelCase(true); return sessionFactory.getObject(); } @Bean public SqlSessionTemplate scheduleSqlSessionTemplate(@Qualifier('scheduleSqlSessionFactory') SqlSessionFactory sqlSessionFactory) throws Exception { return new SqlSessionTemplate(sqlSessionFactory); }}

第二種是動態數據源模式,通過AOP切入注解引導使用何數據源。用自定義注解@interface來標識方法走對應的數據源。

注意事項:類中的方法再調用帶數據源的方法,不能被AOP切入

@Target({ElementType.METHOD, ElementType.TYPE})@Retention(RetentionPolicy.RUNTIME)@Documentedpublic @interface TargetDataSource { String value();}

extends spring的動態DataSource路由來匹配

public class DynamicDataSource extends AbstractRoutingDataSource { @Override protected Object determineCurrentLookupKey() { return DataSourceContextRouting.getDataSourceName(); }}

@Configuration//@EnableConfigurationProperties(MybatisProperties.class)//不要使用此公共配置,Configuration會破壞相關dataSource的配置@MapperScan('com.zss.two.mapper')public class MybatisConfig { @Bean @ConfigurationProperties(prefix = 'spring.datasource.druid.core') public DataSource coreDataSource() { return DruidDataSourceBuilder.create().build(); } @Bean @ConfigurationProperties(prefix = 'spring.datasource.druid.schedule') public DataSource scheduleDataSource() { return DruidDataSourceBuilder.create().build(); } @Autowired @Qualifier('coreDataSource') private DataSource coreDataSource; @Autowired @Qualifier('scheduleDataSource') private DataSource scheduleDataSource; @Bean public DynamicDataSource dataSource() { Map<Object, Object> targetDataSources = new HashMap<>(); targetDataSources.put(DataSourceConstants.CORE_DATA_SOURCE, coreDataSource); targetDataSources.put(DataSourceConstants.SCHEDULE_DATA_SOURCE, scheduleDataSource); DynamicDataSource dataSource = new DynamicDataSource(); //設置數據源映射 dataSource.setTargetDataSources(targetDataSources);//// 設置默認數據源,當無法映射到數據源時會使用默認數據源 dataSource.setDefaultTargetDataSource(coreDataSource); dataSource.afterPropertiesSet(); return dataSource; } /** * 根據數據源創建SqlSessionFactory */ @Bean public SqlSessionFactory sqlSessionFactory(DynamicDataSource dataSource) throws Exception { SqlSessionFactoryBean sessionFactory = new SqlSessionFactoryBean(); sessionFactory.setDataSource(dataSource); sessionFactory.getObject().getConfiguration().setJdbcTypeForNull(null); sessionFactory.getObject().getConfiguration().setMapUnderscoreToCamelCase(true); return sessionFactory.getObject(); } @Bean public SqlSessionTemplate sqlSessionTemplate(SqlSessionFactory sqlSessionFactory) throws Exception { return new SqlSessionTemplate(sqlSessionFactory); }

第三種,自定義Bean命名策略,按beanName進行自動匹配使用數據源

@Componentpublic class CoreBeanNameGenerator implements BeanNameGenerator { @Override public String generateBeanName(BeanDefinition definition, BeanDefinitionRegistry registry) { return 'core'+ ClassUtils.getShortName(definition.getBeanClassName()); }}@Componentpublic class ScheduleBeanNameGenerator implements BeanNameGenerator { @Override public String generateBeanName(BeanDefinition definition, BeanDefinitionRegistry registry) { return 'schedule'+ ClassUtils.getShortName(definition.getBeanClassName()); }}

使用mybatis MapperScannerConfigurer自動掃描,將Mapper接口生成注入到spring

@Bean public MapperScannerConfigurer coreMapperScannerConfig(CoreBeanNameGenerator coreBeanNameGenerator){ MapperScannerConfigurer configurer = new MapperScannerConfigurer(); configurer.setNameGenerator(coreBeanNameGenerator); configurer.setBasePackage('com.zss.third.mapper.core,com.zss.third.mapper.order'); configurer.setSqlSessionFactoryBeanName('coreSqlSessionFactory'); configurer.setSqlSessionTemplateBeanName('coreSqlSessionTemplate'); return configurer; } @Bean public MapperScannerConfigurer scheduleMapperScannerConfig(ScheduleBeanNameGenerator scheduleBeanNameGenerator){ MapperScannerConfigurer configurer = new MapperScannerConfigurer(); configurer.setNameGenerator(scheduleBeanNameGenerator); configurer.setBasePackage('com.zss.third.mapper.schedule,com.zss.third.mapper.order'); configurer.setSqlSessionFactoryBeanName('scheduleSqlSessionFactory'); configurer.setSqlSessionTemplateBeanName('scheduleSqlSessionTemplate'); return configurer; }

到此,三種多數據源匹配主要點介紹完,詳細直接下載github項目。 在resources/db含有相關測試表及數據腳本。

到此這篇關于springboot2+mybatis多種方式實現多數據配置方法的文章就介紹到這了,更多相關springboot2+mybatis 多數據內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Spring
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
国产日本亚洲| 高清不卡亚洲| 国产精品99免费看| 亚洲v在线看| 国产一区精品福利| 日韩三区免费| 国产99亚洲| 日韩专区欧美专区| 蜜臀久久久久久久| 亚州av一区| 国产精品第十页| 岛国av免费在线观看| 亚洲天堂久久| 视频一区中文字幕国产| 日本va欧美va欧美va精品| 美女性感视频久久| 日韩久久精品| 免费成人av在线播放| 久久精品99国产精品日本| 欧美成人aaa| 久久精品123| 日本欧美在线看| 国产欧美精品久久| 亚洲四虎影院| 视频一区中文字幕精品| 精品视频在线一区二区在线| 免费不卡中文字幕在线| 欧美一区二区三区久久| 日韩精品不卡一区二区| 一区二区三区午夜视频| 久久伊人亚洲| 国产婷婷精品| 久久只有精品| 免费黄网站欧美| 九九99久久精品在免费线bt| 欧美91精品| 国产精品日韩精品中文字幕| 美女网站一区| 国产日韩欧美中文在线| 午夜精品成人av| 日精品一区二区三区| 国产一区二区三区天码| 亚洲一区二区毛片| 成人污污视频| 亚洲三级国产| 蜜桃av.网站在线观看| 日韩中文一区二区| 蜜桃精品在线| 日本不卡在线视频| 成人三级高清视频在线看| 日韩中文字幕av电影| 久久男人av资源站| 日韩精品视频在线看| 日韩在线短视频| 欧美一级久久| 国产免费成人| 日韩免费久久| 欧美成人aaa| 日韩精品乱码av一区二区| 久久久久美女| 精品99在线| 国产精选久久| 视频一区日韩| 香蕉久久夜色精品国产| 国产精品99一区二区三区| 欧美亚洲一区二区三区| 蜜桃视频一区二区三区 | 不卡在线一区二区| 国语精品一区| 人人精品久久| 在线免费观看亚洲| 天堂网在线观看国产精品| 国产夫妻在线| 狂野欧美性猛交xxxx| 国产一卡不卡| 日韩高清欧美激情| 蜜桃视频一区二区| 午夜欧美理论片| 亚洲午夜视频| 久久国产日韩| 国产精品字幕| av亚洲一区二区三区| 精品理论电影在线| 狂野欧美性猛交xxxx| 欧美国产极品| 国产欧美高清视频在线| 国产探花一区| 久久精品99久久久| 国产美女亚洲精品7777| 国产日韩欧美一区二区三区在线观看 | av一区在线| 福利一区和二区| 国产盗摄——sm在线视频| 国产一区二区三区久久| 国产成人免费| 日韩在线欧美| 亚洲v在线看| 91精品亚洲| 亚洲第一精品影视| 伊人影院久久| 亚洲日本国产| 国产亚洲一区二区三区啪| 国产图片一区| 欧美国产极品| 国产在线观看www| 国产高清不卡| 亚洲二区精品| 一区二区三区国产盗摄| 日本在线成人| 国产精品99久久久久久董美香| 国产精品亚洲综合久久| 精品久久久久中文字幕小说| 国产精品高颜值在线观看| 成人久久一区| 久久国产66| 欧美日韩一区二区三区四区在线观看| 国产探花一区| 成人美女视频| 模特精品在线| 国产精品自在| 精品国产a一区二区三区v免费| 日韩av在线播放网址| 久久精品国产68国产精品亚洲| 日韩午夜黄色| 欧美日韩 国产精品| 国产精品久久久久久久久妇女| 欧美手机在线| 欧美日韩夜夜| 91精品亚洲| 日韩精品亚洲专区在线观看| 国产精品一卡| 色婷婷精品视频| 亚洲综合婷婷| 国产一区三区在线播放| 欧美特黄一区| 日本午夜免费一区二区| 国产成人精品一区二区三区免费| 国产一区二区三区自拍| 欧美日韩亚洲一区| 久久婷婷久久| 国产图片一区| 久久精品国产www456c0m| 亚洲欧美在线专区| sm捆绑调教国产免费网站在线观看| 黄色日韩在线| 麻豆国产精品777777在线| 久久亚洲成人| 91精品丝袜国产高跟在线| 婷婷综合六月| 欧美另类中文字幕 | 秋霞影院一区二区三区| 五月激激激综合网色播| 日本在线高清| 天堂俺去俺来也www久久婷婷| 精品久久久网| 亚洲麻豆一区| 99久久精品网| 久久99免费视频| 模特精品在线| av综合电影网站| 欧美日韩黄网站| 久久久久欧美精品| 国产精品视频一区二区三区四蜜臂 | 亚洲a一区二区三区| 欧美日一区二区在线观看| 亚洲成人精选| 日韩美女一区二区三区在线观看| 日韩精品1区2区3区| 欧美高清一区| 美女精品视频在线| 亚洲欧洲美洲国产香蕉| 免费视频国产一区| 福利视频一区| 免费亚洲婷婷| 91精品一区| 中文字幕免费精品| 91成人超碰| 日韩av福利| 精品精品99| 国产亚洲人成a在线v网站| 亚洲视频国产| 午夜久久影院| 亚洲一级网站| 国产精品蜜芽在线观看| 国产欧美久久一区二区三区| 首页欧美精品中文字幕| 欧美女激情福利| 日韩一区自拍| 卡一卡二国产精品| 久久精品999| 日本不卡一区二区三区| 一区二区三区国产盗摄| 99精品99| 午夜久久影院| 不卡一区2区| 欧美日韩在线观看视频小说| 91综合网人人| 热三久草你在线| 精精国产xxxx视频在线播放| 国产aⅴ精品一区二区三区久久|