成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

springboot2+mybatis多種方式實(shí)現(xiàn)多數(shù)據(jù)配置方法

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

業(yè)務(wù)系統(tǒng)復(fù)雜程度增加,為了解決數(shù)據(jù)庫(kù)I/O瓶頸,很自然會(huì)進(jìn)行拆庫(kù)拆表分服務(wù)來(lái)應(yīng)對(duì)。這就會(huì)出現(xiàn)一個(gè)系統(tǒng)中可能會(huì)訪問(wèn)多處數(shù)據(jù)庫(kù),需要配置多個(gè)數(shù)據(jù)源。

第一種場(chǎng)景:項(xiàng)目服務(wù)從其它多處數(shù)據(jù)庫(kù)取基礎(chǔ)數(shù)據(jù)進(jìn)行業(yè)務(wù)處理,因此各庫(kù)之間不會(huì)出現(xiàn)重表等情況。

第二種場(chǎng)景:為了減輕寫(xiě)入壓力進(jìn)行讀寫(xiě)分庫(kù),讀走從庫(kù),寫(xiě)為主庫(kù)。此種表名等信息皆為一致。

第三種場(chǎng)景:以上兩種皆有。對(duì)于某些業(yè)務(wù)需要大數(shù)據(jù)量的匯總統(tǒng)計(jì),希望不影響正常業(yè)務(wù)必須走從庫(kù)(表信息一致),某些配置信息不存在讀寫(xiě)壓力,出現(xiàn)不分庫(kù)(表信息不一致)

項(xiàng)目源代碼:

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

有三個(gè)目錄:

one: 直接使用多@Bean配置,@MapperScan來(lái)路徑區(qū)分讀何庫(kù)

two: 使用注解的方式來(lái)標(biāo)識(shí)走何dataSource,AOP攔截注入動(dòng)態(tài)數(shù)據(jù)源

third: 使用spring的Bean命名策略進(jìn)行區(qū)分?jǐn)?shù)據(jù)來(lái)源

項(xiàng)目技術(shù)選型: 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,不然會(huì)報(bào)連接異常。

第一種:通過(guò)@MapperScans 掃描匹配相關(guān)的數(shù)據(jù)源

@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); }}

第二種是動(dòng)態(tài)數(shù)據(jù)源模式,通過(guò)AOP切入注解引導(dǎo)使用何數(shù)據(jù)源。用自定義注解@interface來(lái)標(biāo)識(shí)方法走對(duì)應(yīng)的數(shù)據(jù)源。

注意事項(xiàng):類中的方法再調(diào)用帶數(shù)據(jù)源的方法,不能被AOP切入

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

extends spring的動(dòng)態(tài)DataSource路由來(lái)匹配

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

@Configuration//@EnableConfigurationProperties(MybatisProperties.class)//不要使用此公共配置,Configuration會(huì)破壞相關(guān)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(); //設(shè)置數(shù)據(jù)源映射 dataSource.setTargetDataSources(targetDataSources);//// 設(shè)置默認(rèn)數(shù)據(jù)源,當(dāng)無(wú)法映射到數(shù)據(jù)源時(shí)會(huì)使用默認(rèn)數(shù)據(jù)源 dataSource.setDefaultTargetDataSource(coreDataSource); dataSource.afterPropertiesSet(); return dataSource; } /** * 根據(jù)數(shù)據(jù)源創(chuàng)建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進(jìn)行自動(dòng)匹配使用數(shù)據(jù)源

@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自動(dòng)掃描,將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; }

到此,三種多數(shù)據(jù)源匹配主要點(diǎn)介紹完,詳細(xì)直接下載github項(xiàng)目。 在resources/db含有相關(guān)測(cè)試表及數(shù)據(jù)腳本。

到此這篇關(guān)于springboot2+mybatis多種方式實(shí)現(xiàn)多數(shù)據(jù)配置方法的文章就介紹到這了,更多相關(guān)springboot2+mybatis 多數(shù)據(jù)內(nèi)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標(biāo)簽: Spring
相關(guān)文章:
成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久
日韩一区二区三区三四区视频在线观看| 777奇米四色成人影色区| 国产精品99久久久| 亚洲三级免费| 国产精品久久久久久一区二区三区| 成人自拍视频在线| 制服丝袜中文字幕一区| 日韩成人av影视| 媚黑女一区二区| 亚洲午夜久久久久久久久久久 | 一区二区三区四区乱视频| 亚洲二区在线| 中文字幕一区二区三区不卡在线| 国内精品亚洲| 国产精品狼人久久影院观看方式| 欧美日韩亚洲一区二区三区在线 | 中文字幕国产一区| 欧美视频一区二区| 亚洲你懂的在线视频| 欧美日韩一区二区在线视频| 欧美精品123区| 五月天亚洲精品| 美女精品国产| 亚洲成av人影院在线观看网| 久久精品人人| 日韩国产一区二| 欧美亚洲综合另类| 麻豆国产91在线播放| 欧美日韩国产一区二区三区地区| 久久精品99国产国产精| 欧美天堂一区二区三区| 国产一区二区毛片| 日韩精品一区二区三区中文精品| 色综合中文字幕| 国产精品自拍av| 久久精品国产亚洲a| 久久久久在线| 极品少妇xxxx精品少妇| 欧美一区二区三区精品| 岛国一区二区三区| 久久奇米777| 欧美日韩免费观看一区| 亚洲女与黑人做爰| 午夜一区二区三区不卡视频| 蜜臀91精品一区二区三区 | 日韩限制级电影在线观看| 成人av片在线观看| 国产午夜精品久久久久久久 | 欧美午夜影院一区| 国产一区二区三区国产| 久久网站最新地址| 亚洲高清123| 午夜电影网一区| 欧美亚洲国产bt| 国产精品888| 国产日韩欧美一区二区三区综合| 激情婷婷欧美| 天堂成人免费av电影一区| 911精品国产一区二区在线| 99久久精品免费看国产| 亚洲免费观看在线观看| 色天使久久综合网天天| 黑人巨大精品欧美黑白配亚洲| 9191成人精品久久| 欧美阿v一级看视频| 亚洲图片一区二区| 欧美一区二区三区四区视频| 国产一区亚洲| 日韩av一区二| 日韩精品一区二区三区视频播放| 欧美三级第一页| 亚洲成av人片在www色猫咪| 91精品国产入口在线| 伊人久久av导航| 日本大胆欧美人术艺术动态| 欧美一区二区性放荡片| 免费亚洲一区二区| 国产综合久久久久影院| 精品少妇一区二区三区日产乱码| 狠狠综合久久| 日本强好片久久久久久aaa| 日韩丝袜美女视频| 伊人成人在线| 免费成人av资源网| 欧美国产视频在线| 色视频一区二区| 91麻豆精东视频| 五月激情丁香一区二区三区| 日韩一区二区三区视频在线 | 欧美羞羞免费网站| 欧美一区二区三区久久精品| 日韩国产欧美在线视频| 国产网红主播福利一区二区| 久久五月激情| 91丝袜国产在线播放| 午夜欧美大尺度福利影院在线看| 日韩一卡二卡三卡四卡| 一本色道久久99精品综合| 国产黄色精品视频| 一区二区理论电影在线观看| 精品剧情在线观看| 久久免费99精品久久久久久| 欧美激情四色| 国产精品一级在线| 亚洲精品免费在线观看| 日韩精品专区在线影院观看| 噜噜噜躁狠狠躁狠狠精品视频| 欧美淫片网站| 蜜臀va亚洲va欧美va天堂| 国产精品成人在线观看| 欧美一级一级性生活免费录像| 亚洲欧美高清| 欧美日韩国产免费观看 | 精品一区二区三区久久| 亚洲另类春色国产| 亚洲精品在线电影| 91久久精品日日躁夜夜躁欧美| 欧美午夜a级限制福利片| 久久成人av少妇免费| 亚洲影院免费观看| 欧美国产精品专区| 91.xcao| 国产精品一区视频网站| 欧美片网站免费| 国产精品99久久久久久有的能看 | 精品欧美一区二区在线观看| 狂野欧美性猛交xxxx巴西| 国产在线精品二区| 成人性生交大片免费看中文网站| 蜜臀av一级做a爰片久久| 亚洲日本乱码在线观看| 日韩精品专区在线| 欧美在线免费观看视频| 国产麻豆综合| 一区二区三区我不卡| 91免费观看在线| 国产传媒一区在线| 久久福利视频一区二区| 亚洲小说欧美激情另类| 国产欧美久久久精品影院| 欧美一激情一区二区三区| 色婷婷综合久色| 亚洲毛片av| 欧美色123| 91在线porny国产在线看| 麻豆国产精品一区二区三区 | 精品三级在线观看| 亚洲精品一区二区三区精华液| 精品久久久久一区二区国产| 亚洲大片在线观看| 亚洲精品偷拍| 亚洲国产日日夜夜| 国产欧美一区在线| 精品国产成人在线影院| 欧美一区二视频| 欧美自拍偷拍一区| 免播放器亚洲| 国产精品美女黄网| 一区二区在线不卡| 国内精品久久久久久久果冻传媒| 91免费观看国产| 99久久久无码国产精品| av在线不卡免费看| 成人av在线资源| 成人avav在线| 成人一级片网址| 国产精品亚洲视频| 国产九色sp调教91| 国产盗摄一区二区三区| 国产大陆精品国产| 国产精品12区| 国产一区二区三区视频在线播放| 美女网站在线免费欧美精品| 美国av一区二区| 久久99热这里只有精品| 久久99精品久久久久久久久久久久| 日韩电影免费在线观看网站| 天天综合天天做天天综合| 午夜电影网一区| 亚洲成人午夜电影| 亚洲一区二区三区在线看| 亚洲一区二区精品久久av| 亚洲资源在线观看| 午夜免费久久看| 日韩中文字幕亚洲一区二区va在线| 亚洲成人先锋电影| 日本免费新一区视频 | 99re这里只有精品首页| www.亚洲在线| 欧美69视频| 好吊日精品视频| 亚洲人www| 久久成人亚洲| 一本久道中文字幕精品亚洲嫩| 日本高清不卡一区| 欧美日本国产视频| 日韩视频免费观看高清在线视频| 精品国精品国产尤物美女| 国产日韩欧美麻豆| 欧美国产日韩一二三区|