亚洲免费在线视频-亚洲啊v-久久免费精品视频-国产精品va-看片地址-成人在线视频网

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

SpringBoot+mybatis實(shí)現(xiàn)多數(shù)據(jù)源支持操作

瀏覽:96日期:2023-04-16 15:37:50

什么是多數(shù)據(jù)源支持?

簡(jiǎn)單的說,就是一個(gè)項(xiàng)目里,同時(shí)可以訪問多個(gè)不同的數(shù)據(jù)庫(kù)。

實(shí)現(xiàn)原理

單個(gè)數(shù)據(jù)源在配置時(shí)會(huì)綁定一套mybatis配置,多個(gè)數(shù)據(jù)源時(shí),不同的數(shù)據(jù)源綁定不同的mybatis配置就可以了,簡(jiǎn)單的思路就是讓不同的數(shù)據(jù)源掃描不同的包,讓不同的包下的mapper對(duì)應(yīng)連接不同的數(shù)據(jù)源去處理邏輯。

業(yè)務(wù)場(chǎng)景假設(shè)

項(xiàng)目底層有正常業(yè)務(wù)庫(kù)和日志庫(kù),希望解決的是將項(xiàng)目中的一些日志單獨(dú)記錄到一個(gè)庫(kù)里,比如用戶操作記錄、產(chǎn)品更新記錄等。

說一下為什么會(huì)有這個(gè)需求:用戶操作記錄和產(chǎn)品更新記錄可能很多,而實(shí)際中使用的又很少,就只是在某些頁(yè)面單獨(dú)展示一下操作或更新記錄,絕大部分時(shí)間都在不停的做著插入操作,這時(shí)就可以把這種記錄放到業(yè)務(wù)核心庫(kù)外面。

實(shí)現(xiàn)步驟

1.定義多個(gè)數(shù)據(jù)源的mybatis配置

application.properties mybatis.mapper-locations=mappers/*.xmlmybatisLog.mapper-locations=mappersLog/*.xml## datasource master #spring.datasource.type=com.alibaba.druid.pool.DruidDataSourcespring.datasource.driver-class-name=com.mysql.jdbc.Driverspring.datasource.url=jdbc:mysql://localhost:3306/test1?characterEncoding=UTF-8spring.datasource.username=rootspring.datasource.password=466420182## datasource log #spring.datasourceLog.type=com.alibaba.druid.pool.DruidDataSourcespring.datasourceLog.driver-class-name=com.mysql.jdbc.Driverspring.datasourceLog.url=jdbc:mysql://localhost:3306/log?characterEncoding=UTF-8spring.datasourceLog.username=rootspring.datasourceLog.password=466420182

2.定義多個(gè)數(shù)據(jù)源

@Configurationpublic class DatasourceConfig { @Bean(destroyMethod = 'close', name = DataSources.MASTER_DB) @ConfigurationProperties(prefix = 'spring.datasource') public DataSource dataSource() { return DataSourceBuilder.create().type(DruidDataSource.class).build(); } @Bean(destroyMethod = 'close', name = DataSources.LOG_DB) @ConfigurationProperties(prefix = 'spring.datasourceLog') public DataSource dataSourceLog() { return DataSourceBuilder.create().type(DruidDataSource.class).build(); }}

3.分別配置多個(gè)數(shù)據(jù)源

@Configuration@MapperScan(basePackages = {'com.mmall.practice.dao'})public class MybatisConfig { @Autowired @Qualifier(DataSources.MASTER_DB) private DataSource masterDB; @Bean @Primary @ConfigurationProperties(prefix = 'mybatis') public SqlSessionFactoryBean sqlSessionFactoryBean() { SqlSessionFactoryBean sqlSessionFactoryBean = new SqlSessionFactoryBean(); sqlSessionFactoryBean.setDataSource(masterDB); return sqlSessionFactoryBean; }}

@Configuration@MapperScan(basePackages = {'com.mmall.practice.daoLog'}, sqlSessionFactoryRef = 'logSqlSessionFactory')public class MybatisLogConfig { @Autowired @Qualifier('logDB') private DataSource logDB; @Bean(name = 'logSqlSessionFactory') @ConfigurationProperties(prefix = 'mybatisLog') public SqlSessionFactoryBean sqlSessionFactoryBean() { SqlSessionFactoryBean sqlSessionFactoryBean = new SqlSessionFactoryBean(); sqlSessionFactoryBean.setDataSource(logDB); return sqlSessionFactoryBean; }}

這里需要注意兩個(gè)數(shù)據(jù)源配置的差別,也是支持多數(shù)據(jù)源的關(guān)鍵

1)Configuration 掃描不同的前綴,取不同包下的sql對(duì)應(yīng)的xml文件

2)SqlSessionFactoryBean 實(shí)例化時(shí),默認(rèn)的額外添加了 @Primary注解

3)MapperScan 掃描的不同的包,如果掃描相同的包也能做,但是還需要做額外的配置,可以自己嘗試

4)不同的數(shù)據(jù)源使用不同的SqlSessionFactoryBean實(shí)例

至此,不同包下面的 Mapper.java 文件就可以連接不同的數(shù)據(jù)源了。這里就不說如何去使用了,和之前正常一樣去使用 Mapper.java 就可以了,只是操作的是不同的數(shù)據(jù)庫(kù)。

補(bǔ)充知識(shí):springboot+mybatis多數(shù)據(jù)源不用增加硬編碼,只需簡(jiǎn)單配置即可

背景

原有系統(tǒng)增加統(tǒng)計(jì)功能,數(shù)據(jù)源有本地系統(tǒng)的數(shù)據(jù),還有其他系統(tǒng)數(shù)據(jù)。其他系統(tǒng)數(shù)據(jù)可以同步到mysql表。但是又不想與當(dāng)前頁(yè)面表混用,打算使用另外的庫(kù),并且不想單獨(dú)提供接口,想通過當(dāng)前系統(tǒng)配置數(shù)據(jù)源來實(shí)現(xiàn)此功能。

目前常用的方式是分包或切面等,感覺要改的地方比較多,最后采用了一種改動(dòng)最簡(jiǎn)單的方式來實(shí)現(xiàn)多數(shù)據(jù)源,shardingjdbc這種方式,感覺比較簡(jiǎn)單,而且便于日后分庫(kù)分表的拓展。

項(xiàng)目實(shí)施

目標(biāo)

系統(tǒng)增加一個(gè)數(shù)據(jù)源,統(tǒng)計(jì)數(shù)據(jù),此數(shù)據(jù)源與系統(tǒng)原有數(shù)據(jù)源不發(fā)生關(guān)系。

當(dāng)前環(huán)境

viewer.sql:原業(yè)務(wù)庫(kù),大概有二十多張表(當(dāng)前舉例,展示user,role)

test.sql:新增的統(tǒng)計(jì)庫(kù),目前只使用一張表(模擬統(tǒng)計(jì)測(cè)試數(shù)據(jù)zhy)

使用mybatis,自動(dòng)生成了原業(yè)務(wù)的mapper和test中zhy表的數(shù)據(jù)

代碼

第一步 引入shardingjdbc依賴

gradle

compile ’org.apache.shardingsphere:sharding-jdbc-spring-boot-starter:4.0.1’

maven

<dependency> <groupId>org.apache.shardingsphere</groupId> <artifactId>sharding-jdbc-spring-boot-starter</artifactId> <version>4.0.1</version></dependency>

第二步 配置properties

原來連接數(shù)據(jù)庫(kù)

# jdbc_config datasourcespring.datasource.driver-class-name=com.mysql.cj.jdbc.Driverspring.datasource.url=jdbc:mysql://127.0.0.1:3306/viewer?useUnicode=true&characterEncoding=UTF-8&autoReconnect=true&useSSL=false&zeroDateTimeBehavior=CONVERT_TO_NULL&serverTimezone=UTCspring.datasource.username=rootspring.datasource.password=123456# Hikari will use the above plus the following to setup connection poolingspring.datasource.type=com.zaxxer.hikari.HikariDataSourcespring.datasource.hikari.minimum-idle=5spring.datasource.hikari.maximum-pool-size=15spring.datasource.hikari.auto-commit=truespring.datasource.hikari.idle-timeout=30000spring.datasource.hikari.pool-name=DatebookHikariCPspring.datasource.hikari.max-lifetime=1800000spring.datasource.hikari.connection-timeout=30000spring.datasource.hikari.connection-test-query=SELECT 1

修改后

spring.shardingsphere.datasource.names=ds-viewer,ds-test# 系統(tǒng)原有數(shù)據(jù)源spring.shardingsphere.datasource.ds-viewer.type=com.zaxxer.hikari.HikariDataSourcespring.shardingsphere.datasource.ds-viewer.driver-class-name=com.mysql.cj.jdbc.Driverspring.shardingsphere.datasource.ds-viewer.jdbc-url=jdbc:mysql://127.0.0.1:3306/viewer?useUnicode=true&characterEncoding=UTF-8&autoReconnect=true&useSSL=false&zeroDateTimeBehavior=CONVERT_TO_NULL&serverTimezone=UTCspring.shardingsphere.datasource.ds-viewer.username=rootspring.shardingsphere.datasource.ds-viewer.password=123456# 新增統(tǒng)計(jì)數(shù)據(jù)源spring.shardingsphere.datasource.ds-test.type=com.zaxxer.hikari.HikariDataSourcespring.shardingsphere.datasource.ds-test.driver-class-name=com.mysql.cj.jdbc.Driverspring.shardingsphere.datasource.ds-test.jdbc-url=jdbc:mysql://127.0.0.1:3306/test?useUnicode=true&characterEncoding=UTF-8&autoReconnect=true&useSSL=false&zeroDateTimeBehavior=CONVERT_TO_NULL&serverTimezone=UTCspring.shardingsphere.datasource.ds-test.username=rootspring.shardingsphere.datasource.ds-test.password=123456# 規(guī)則spring.shardingsphere.sharding.tables.user.actual-data-nodes=ds-viewer.userspring.shardingsphere.sharding.tables.role.actual-data-nodes=ds-viewer.rolespring.shardingsphere.sharding.tables.zhy.actual-data-nodes=ds-test.zhy

主要需要看,配置分片規(guī)則這塊,根據(jù)表名進(jìn)行分庫(kù)。

spring.shardingsphere.sharding.tables.user.actual-data-nodes=ds-viewer.user

解釋:

user:原有數(shù)據(jù)庫(kù)中的表

ds-viewer:定義的數(shù)據(jù)源spring.shardingsphere.datasource.names=ds-viewer,ds-test

有幾張表就可以定義幾張(可以使用idea縱列編輯,很方便改造)

大功告成,可以進(jìn)行開發(fā)測(cè)試了,對(duì)于代碼層來說,沒有任何改動(dòng)。

如果系統(tǒng)有配置文件,有的配置啟動(dòng)不需要多數(shù)據(jù)源,可以在配置文件中禁止啟動(dòng)shardingjdbc

spring.shardingsphere.enabled=false

以上這篇SpringBoot+mybatis實(shí)現(xiàn)多數(shù)據(jù)源支持操作就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持好吧啦網(wǎng)。

標(biāo)簽: Spring
相關(guān)文章:
主站蜘蛛池模板: 欧美日韩在线观看精品 | 一级做a爰性色毛片免费 | 交视频在线观看国产网站 | 999热精品这里在线观看 | 中文字幕欧美日韩一 | 成人欧美精品大91在线 | 一区二区三区四区免费视频 | 美女叉开腿让男人捅 | 国产黄色三级网站 | 国内精品久久久久久久星辰影视 | 欧美一级日韩一级亚洲一级 | 久久精品国产三级不卡 | 欧美视频在线网站 | 一级毛片美国一级j毛片不卡 | 在线观看黄网视频免费播放 | 亚洲天堂2018av| 中文字幕精品一区二区绿巨人 | 亚洲精品一区二区三区网址 | 欧美成人亚洲综合精品欧美激情 | 美女国产福利视频 | 欧美成人自拍 | 免费黄色网址在线播放 | 久久精品国产影库免费看 | 久草国产在线 | avtom影院入口永久在线 | 亚洲精品亚洲一区二区 | 日韩毛片免费视频一级特黄 | 久久男人的天堂色偷偷 | 国产精品9999久久久久 | 久久精品免视看国产明星 | 亚洲视频免费播放 | 免费人成黄页网站在线观看国产 | 国产香蕉98碰碰久久人人 | 国产一级毛片国语版 | 国产午夜精品理论片免费观看 | 日本一级特黄特色大片免费视频 | 激情午夜天 | 国产欧美在线视频 | 亚洲国产www| 欧美亚洲国产成人综合在线 | 亚洲 中文 欧美 日韩 在线人 |