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

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

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

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

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

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

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

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

項(xiàng)目源代碼:

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

有三個(gè)目錄:

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

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

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

項(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,不然會報(bào)連接異常。

第一種:通過@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); }}

第二種是動態(tài)數(shù)據(jù)源模式,通過AOP切入注解引導(dǎo)使用何數(shù)據(jù)源。用自定義注解@interface來標(biāo)識方法走對應(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的動態(tài)DataSource路由來匹配

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

@Configuration//@EnableConfigurationProperties(MybatisProperties.class)//不要使用此公共配置,Configuration會破壞相關(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)無法映射到數(shù)據(jù)源時(shí)會使用默認(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)行自動匹配使用數(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自動掃描,將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)測試表及數(shù)據(jù)腳本。

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

標(biāo)簽: Spring
相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
亚洲欧美综合| 视频一区欧美精品| 69堂免费精品视频在线播放| 视频一区二区欧美| 午夜一区在线| 手机精品视频在线观看| 免费国产亚洲视频| 亚洲毛片视频| 无码日韩精品一区二区免费| 亚洲精品综合| 日本强好片久久久久久aaa| 亚洲精品黄色| 欧美一区在线观看视频| 国产乱码精品| 精品五月天堂| 精品国产中文字幕第一页| 精品中文在线| 精品网站999| 亚洲成人一区在线观看| 亚洲一级特黄| 免费观看日韩电影| 日本天堂一区| 六月丁香综合在线视频| 国产美女高潮在线| 香蕉人人精品| 一区二区电影在线观看| 国产亚洲欧美日韩精品一区二区三区| 麻豆一区在线| 香蕉成人av| 亚洲免费影院| 亚洲精品乱码日韩| 国产伦精品一区二区三区千人斩| 精品一区二区三区亚洲| 久久婷婷亚洲| 最新亚洲国产| 麻豆91精品91久久久的内涵| 深夜福利视频一区二区| 伊人精品在线| 国产精品尤物| 国产91一区| 日本一区二区三区中文字幕| 麻豆精品久久久| 午夜欧美在线| 日本欧美一区| 三级小说欧洲区亚洲区| 亚洲综合欧美| 精品国产欧美| 久久亚洲风情| 精品国产成人| 另类国产ts人妖高潮视频| 国产精品久久久免费| 99久久婷婷| 久久精品超碰| 激情欧美丁香| 国产精品v亚洲精品v日韩精品| 99久久久久久中文字幕一区| 欧美亚洲一级| 欧美a级片一区| 欧美在线不卡| 欧美理论视频| 久久精品99国产精品| 欧美日韩水蜜桃| 国产日韩免费| 欧美日韩免费观看一区=区三区| 国产另类在线| 午夜在线观看免费一区| 国产66精品| 亚洲精品高潮| 久久久久久久久丰满| 欧美亚洲免费| 99pao成人国产永久免费视频| 免费一级欧美片在线观看网站 | 亚洲香蕉久久| 国产aⅴ精品一区二区三区久久| 免费不卡在线视频| 桃色av一区二区| 国产日韩一区二区三区在线| 亚洲精品成人| 丁香婷婷久久| 日韩动漫一区| 亚洲欧洲另类| 天堂√8在线中文| 久久精品超碰| 日韩中文字幕1| 日韩欧美综合| 久久99青青| 四虎成人精品一区二区免费网站| 久久精品国内一区二区三区水蜜桃| 欧美国产极品| 亚洲精品国模| 99国产精品| 四虎4545www国产精品| 欧美黑人巨大videos精品| 亚洲乱亚洲高清| 好看的av在线不卡观看| а√天堂8资源中文在线| 久久av免费看| 国产精品嫩草影院在线看| 亚洲精品极品| 在线免费观看亚洲| 91久久中文| 婷婷亚洲五月| 久久久天天操| 亚洲www啪成人一区二区| 久久精品理论片| 欧美a级一区二区| 国产精品久一| 美女在线视频一区| 麻豆一区在线| 精品国产一区二区三区av片| 久久99精品久久久野外观看| 国产极品一区| 国产精品一区亚洲| 日本亚洲最大的色成网站www| 午夜国产精品视频| 综合欧美亚洲| 久久国产精品久久久久久电车| 亚洲精品极品少妇16p| 亚洲黄色免费看| 日韩国产欧美在线视频| 蜜臀久久99精品久久久画质超高清| 亚洲午夜视频| 91精品一区二区三区综合| 蜜桃视频在线网站| 三级在线看中文字幕完整版| 欧美成人a交片免费看| 激情久久99| 成人免费一区| 欧美激情另类| 免费污视频在线一区| 日韩在线观看不卡| 亚洲福利久久| 亚洲一区二区毛片| 亚洲精品欧洲| 青青国产精品| 久久只有精品| 国产v日韩v欧美v| 91精品亚洲| 性一交一乱一区二区洋洋av| 亚洲欧美在线专区| 国产亚洲第一伦理第一区| 国产日产精品一区二区三区四区的观看方式| 国产亚洲精品美女久久| 精品国产中文字幕第一页| 免费福利视频一区二区三区| 久久精品动漫| 国产精品美女久久久浪潮软件| 蜜桃久久久久久久| 欧美亚洲色图校园春色| 国产精品一区高清| 精品资源在线| 久久裸体视频| 中文字幕一区二区三区在线视频| 日本v片在线高清不卡在线观看| 欧美视频精品全部免费观看| 精品一区二区三区中文字幕| 亚洲91视频| 亚洲香蕉久久| 国产aⅴ精品一区二区三区久久 | 久久久夜精品| 免费观看在线综合| 久久丁香四色| 国产中文在线播放| 伊人影院久久| 人人爱人人干婷婷丁香亚洲| 精品成av人一区二区三区| 亚洲高清二区| 日韩精品成人在线观看| 国产a亚洲精品| 在线视频精品| 欧美日韩网址| 夜鲁夜鲁夜鲁视频在线播放| aa国产精品| 国产精品一区二区av日韩在线| 91中文字幕精品永久在线| 中文一区二区| 麻豆精品视频在线观看免费| 国产精品av一区二区| 日本亚洲不卡| 日韩在线综合| 国产亚洲精aa在线看| 亚洲1234区| 青青国产精品| 欧美+亚洲+精品+三区| 国产精品毛片视频| 99国产精品视频免费观看一公开 | 久久尤物视频| 尤物在线精品| 久久伊人亚洲| 亚洲一区二区三区四区五区午夜| 麻豆中文一区二区| 视频一区免费在线观看| 日韩av在线中文字幕| 日韩中文字幕区一区有砖一区 | 日韩欧美精品综合| 日本不卡在线视频| 亚洲福利一区| 美女免费视频一区| 中文字幕日本一区二区| 亚洲成av人片一区二区密柚|