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

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

SpringBoot+mybatis實現多數據源支持操作

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

什么是多數據源支持?

簡單的說,就是一個項目里,同時可以訪問多個不同的數據庫。

實現原理

單個數據源在配置時會綁定一套mybatis配置,多個數據源時,不同的數據源綁定不同的mybatis配置就可以了,簡單的思路就是讓不同的數據源掃描不同的包,讓不同的包下的mapper對應連接不同的數據源去處理邏輯。

業務場景假設

項目底層有正常業務庫和日志庫,希望解決的是將項目中的一些日志單獨記錄到一個庫里,比如用戶操作記錄、產品更新記錄等。

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

實現步驟

1.定義多個數據源的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.定義多個數據源

@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.分別配置多個數據源

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

這里需要注意兩個數據源配置的差別,也是支持多數據源的關鍵

1)Configuration 掃描不同的前綴,取不同包下的sql對應的xml文件

2)SqlSessionFactoryBean 實例化時,默認的額外添加了 @Primary注解

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

4)不同的數據源使用不同的SqlSessionFactoryBean實例

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

補充知識:springboot+mybatis多數據源不用增加硬編碼,只需簡單配置即可

背景

原有系統增加統計功能,數據源有本地系統的數據,還有其他系統數據。其他系統數據可以同步到mysql表。但是又不想與當前頁面表混用,打算使用另外的庫,并且不想單獨提供接口,想通過當前系統配置數據源來實現此功能。

目前常用的方式是分包或切面等,感覺要改的地方比較多,最后采用了一種改動最簡單的方式來實現多數據源,shardingjdbc這種方式,感覺比較簡單,而且便于日后分庫分表的拓展。

項目實施

目標

系統增加一個數據源,統計數據,此數據源與系統原有數據源不發生關系。

當前環境

viewer.sql:原業務庫,大概有二十多張表(當前舉例,展示user,role)

test.sql:新增的統計庫,目前只使用一張表(模擬統計測試數據zhy)

使用mybatis,自動生成了原業務的mapper和test中zhy表的數據

代碼

第一步 引入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

原來連接數據庫

# 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# 系統原有數據源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# 新增統計數據源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# 規則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

主要需要看,配置分片規則這塊,根據表名進行分庫。

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

解釋:

user:原有數據庫中的表

ds-viewer:定義的數據源spring.shardingsphere.datasource.names=ds-viewer,ds-test

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

大功告成,可以進行開發測試了,對于代碼層來說,沒有任何改動。

如果系統有配置文件,有的配置啟動不需要多數據源,可以在配置文件中禁止啟動shardingjdbc

spring.shardingsphere.enabled=false

以上這篇SpringBoot+mybatis實現多數據源支持操作就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持好吧啦網。

標簽: Spring
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
视频福利一区| 成人台湾亚洲精品一区二区| 国语对白精品一区二区| 久久精品国产精品亚洲毛片| 欧美xxxx性| 日韩av专区| 欧美日韩国产v| 九色porny丨国产首页在线| 久久天堂av| 亚洲五月婷婷| 久久亚洲国产精品一区二区| 首页国产欧美日韩丝袜| 自拍日韩欧美| 视频在线在亚洲| 久久国产生活片100| 鲁大师精品99久久久| 波多视频一区| 亚洲激情中文| 日韩欧美美女在线观看| 国产日韩三级| 国产伦久视频在线观看| 亚洲激情五月| 欧美精品福利| 四虎884aa成人精品最新| 日韩一区二区免费看| 日本va欧美va欧美va精品| 欧美国产亚洲精品| 日韩成人精品一区| 欧美99久久| 天海翼亚洲一区二区三区| 精品国产乱码久久久久久1区2匹| 激情欧美一区| 国产伦一区二区三区| 亚洲特色特黄| 日本视频在线一区| 在线日韩电影| 欧美色综合网| 99精品网站| 久久国内精品| 午夜精品免费| 精品国产三区在线| 视频一区二区不卡| 久久免费精品| 99视频精品免费观看| 欧美亚洲tv| 欧美精品一二| 欧美激情视频一区二区三区免费 | 美国欧美日韩国产在线播放| 麻豆精品新av中文字幕| 在线一区二区三区视频| 久久精品国产亚洲一区二区三区| 亚洲免费播放| 国产精品99视频| 亚洲精选久久| 亚洲va中文在线播放免费| 亚洲人成在线影院| 国产a亚洲精品| 日本免费新一区视频| 国产伊人精品| 国产一区二区三区视频在线| 首页欧美精品中文字幕| 成人羞羞视频播放网站| 国产精品乱战久久久| 午夜精品网站| 首页国产精品| 天堂精品久久久久| 亚洲二区在线| 国内精品麻豆美女在线播放视频| 日韩1区2区3区| 一区在线观看| 日韩精品一区二区三区免费观影| 国产精品啊v在线| 亚洲精品乱码日韩| 丝袜美腿亚洲色图| 国产99久久| 伊人久久av| 另类小说一区二区三区| 日韩精品五月天| 影音先锋久久| 国产精品99一区二区| 亚洲精品成人图区| 老牛国内精品亚洲成av人片| 日韩久久一区| 日本一区二区三区中文字幕| 国产精品普通话对白| 欧美精品一区二区三区精品| 另类专区亚洲| av资源新版天堂在线| 精品国产乱码| 裤袜国产欧美精品一区| 国产成人精品一区二区三区视频| 国产亚洲精品美女久久| 日韩精品91亚洲二区在线观看| 天堂av在线一区| 中文国产一区| 久久都是精品| 天堂成人国产精品一区| 男女男精品网站| 亚洲精品进入| 日本午夜精品一区二区三区电影| 日本国产欧美| 国产亚洲高清在线观看| 国产日韩欧美一区二区三区| 国产精品jk白丝蜜臀av小说| 国产精品主播在线观看| 国产精品115| 福利片在线一区二区| 欧美激情另类| 亚洲高清二区| 久久的色偷偷| 日韩成人午夜精品| 国产欧美日韩| 先锋亚洲精品| 欧美aaaaaa午夜精品| 国产亚洲一区二区三区啪| 一区久久精品| 亚洲激情国产| 亚洲精品在线二区| 青青国产精品| 国内一区二区三区| 日本免费一区二区三区四区| 精品日韩视频| 视频一区欧美日韩| 日韩av网站免费在线| 麻豆精品久久久| 欧美成a人免费观看久久| 亚洲作爱视频| 亚洲精品人人| 欧美激情福利| 久久久9色精品国产一区二区三区| 欧美.日韩.国产.一区.二区| 精品1区2区3区4区| 日韩美女精品| 精品少妇一区| 亚洲手机视频| 欧美永久精品| 欧美日韩国产v| 日本伊人久久| 在线看片福利| 亚洲欧洲国产精品一区| 精品一级视频| 黄色亚洲大片免费在线观看| 国产欧美日韩精品一区二区免费 | 在线免费观看亚洲| 麻豆精品蜜桃视频网站| 亚洲激情中文在线| 91精品尤物| 九九综合在线| 国产剧情一区二区在线观看| 亚洲成人va| 国产午夜精品一区在线观看| 久久中文字幕二区| 欧美国产日本| 中文字幕日韩高清在线| 中文字幕在线高清| 在线观看一区| 精品亚洲美女网站| 国产欧美一级| 狠狠久久婷婷| 日产午夜精品一线二线三线| 视频一区中文字幕精品| 久久国产中文字幕| 欧美1区2区3| 亚洲免费资源| av一区二区高清| 国产一区二区三区亚洲综合| 亚洲丝袜美腿一区| 91精品精品| 久久免费影院| 婷婷综合一区| 亚洲午夜电影| 久久午夜影院| 91精品丝袜国产高跟在线| 夜夜嗨一区二区| 亚洲天堂免费电影| 免费在线亚洲欧美| 日韩精品一区二区三区av| 五月综合激情| 日韩精品麻豆| 高潮一区二区| 精品亚洲成人| 国产精品一区毛片| 日韩不卡手机在线v区| 国产亚洲精品v| 999国产精品999久久久久久| 精品色999| 久久gogo国模啪啪裸体| 日韩不卡一二三区| 视频一区中文字幕精品 | 亚洲人成网站在线在线观看| 久久久久久久久久久9不雅视频| 久久免费福利| 国产日韩三级| 日本色综合中文字幕| 中文字幕日韩亚洲| 综合激情五月婷婷| 亚洲一区导航| 日韩精品一二三| 免费久久99精品国产自在现线| 久久精品不卡|