springboot連接多個(gè)數(shù)據(jù)庫(kù)的實(shí)現(xiàn)方法
一個(gè)SpringBoot項(xiàng)目,同時(shí)連接兩個(gè)數(shù)據(jù)庫(kù):比如一個(gè)是Mysql數(shù)據(jù)庫(kù),一個(gè)是oracle數(shù)據(jù)庫(kù)(啥數(shù)據(jù)庫(kù)都一樣,連接兩個(gè)同為oracle的數(shù)據(jù)庫(kù),或兩個(gè)不同的數(shù)據(jù)庫(kù),只需要更改對(duì)應(yīng)的driver-class-name和jdbc-url等即可)注意:連接什么數(shù)據(jù)庫(kù),要引入對(duì)應(yīng)數(shù)據(jù)庫(kù)的包。
第一步:
導(dǎo)入pom
<dependency> <groupId>com.alibaba</groupId> <artifactId>druid</artifactId> <version>1.1.0</version> </dependency> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <scope>runtime</scope> </dependency>
第二步:
修改application.yml配置文件(我采用本地的,IP地址是一致的,實(shí)際開發(fā)中,是兩臺(tái)云服務(wù),兩臺(tái)MySQL地址進(jìn)行主從讀寫)
mysql1: driver-class-name: com.mysql.cj.jdbc.Driver jdbcUrl: jdbc:mysql://localhost:3306/test?useSSL=false&useUnicode=true&characterEncoding=UTF-8&serverTimezone=GMT%2B8 username: "root" password: "12345678" type: com.alibaba.druid.pool.DruidDataSource mysql2: driver-class-name: com.mysql.cj.jdbc.Driver jdbcUrl: jdbc:mysql://localhost:3306/test1?useSSL=false&useUnicode=true&characterEncoding=UTF-8&serverTimezone=GMT%2B8 username: "root" password: "12345678" type: com.alibaba.druid.pool.DruidDataSource
注意格式
上面spring.datasource省略了
第三步:
建造配置類:
(1)第一個(gè)庫(kù)配置信息:
/** * 數(shù)據(jù)庫(kù)leadnews_article */ @Configuration @MapperScan(basePackages = {"com.example.demo.mapper.db1"}, sqlSessionFactoryRef = "sqlSessionFactoryArticle") public class DBSrcArticle { @Bean public SqlSessionFactory sqlSessionFactoryArticle(@Qualifier("mysql1") DataSource dataSource) throws Exception { MybatisSqlSessionFactoryBean sqlSessionFactory = new MybatisSqlSessionFactoryBean(); sqlSessionFactory.setDataSource(dataSource); sqlSessionFactory.setMapperLocations(new PathMatchingResourcePatternResolver() .getResources("classpath:mapper/db1/*.xml")); return sqlSessionFactory.getObject(); } @Bean public SqlSessionTemplate sqlSessionTemplateArticle(@Qualifier("sqlSessionFactoryArticle") SqlSessionFactory sqlSessionFactory) throws Exception { return new SqlSessionTemplate(sqlSessionFactory); } }
(2)第二個(gè)庫(kù)配置
/** * 數(shù)據(jù)庫(kù)leadnews_user */ @Configuration @MapperScan(basePackages = {"com.example.demo.mapper.db2"}, sqlSessionFactoryRef = "sqlSessionFactoryUser") public class dBSrcUser { @Bean @Primary public SqlSessionFactory sqlSessionFactoryUser(@Qualifier("mysql2") DataSource dataSource) throws Exception { MybatisSqlSessionFactoryBean sqlSessionFactory = new MybatisSqlSessionFactoryBean(); sqlSessionFactory.setDataSource(dataSource); sqlSessionFactory.setMapperLocations(new PathMatchingResourcePatternResolver() .getResources("classpath:mapper/db2/*.xml")); return sqlSessionFactory.getObject(); } @Bean @Primary public SqlSessionTemplate sqlSessionTemplateUser(@Qualifier("sqlSessionFactoryUser") SqlSessionFactory sqlSessionFactory) throws Exception { return new SqlSessionTemplate(sqlSessionFactory); } }
(3)數(shù)據(jù)源配置:
/** * 數(shù)據(jù)源配置 */ @Configuration public class DataSourceConfig { @Primary @Bean(name = "mysql1") @ConfigurationProperties(prefix = "spring.datasource.mysql1") public DataSource dBSrcArticle() { return DataSourceBuilder.create().build(); } @Primary @Bean(name = "mysql2") @ConfigurationProperties(prefix = "spring.datasource.mysql2") public DataSource dBSrcUser() { return DataSourceBuilder.create().build(); } }
注意:連接兩個(gè)以上的數(shù)據(jù)庫(kù),需要對(duì)mapper文件夾進(jìn)行分包
!
第四步:
在啟動(dòng)類中加上這三個(gè)注解:
@SpringBootApplication(exclude = {DataSourceAutoConfiguration.class}) @MapperScan(basePackages = {"com.example.demo.entity.db1"}, sqlSessionFactoryRef = "sqlSessionFactoryArticle") @MapperScan(basePackages = {"com.example.demo.entity.db2"}, sqlSessionFactoryRef = "sqlSessionFactoryUser")
此時(shí):已經(jīng)可以訪問兩個(gè)數(shù)據(jù)庫(kù)內(nèi)容了。
到此這篇關(guān)于springboot連接多個(gè)庫(kù)的實(shí)現(xiàn)方法的文章就介紹到這了,更多相關(guān)springboot連接多個(gè)庫(kù)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- SpringBoot配置Hikari數(shù)據(jù)庫(kù)連接池的詳細(xì)步驟
- springboot項(xiàng)目連接多種數(shù)據(jù)庫(kù)該如何操作詳析
- IDEA中SpringBoot項(xiàng)目數(shù)據(jù)庫(kù)連接加密方法
- SpringBoot項(xiàng)目中連接Gauss數(shù)據(jù)庫(kù)
- 詳解如何在SpringBoot中配置MySQL數(shù)據(jù)庫(kù)的連接數(shù)
- SpringBoot配置多個(gè)數(shù)據(jù)源超簡(jiǎn)單步驟(連接多個(gè)數(shù)據(jù)庫(kù))
- 解決Springboot不能自動(dòng)提交數(shù)據(jù)庫(kù)連接問題
相關(guān)文章
Java ArrayList集合詳解(Java動(dòng)態(tài)數(shù)組)
這篇文章主要介紹了Java ArrayList集合詳解(Java動(dòng)態(tài)數(shù)組),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-10-10Java HttpURLConnection超時(shí)和IO異常處理
這篇文章主要介紹了Java HttpURLConnection超時(shí)和IO異常處理的相關(guān)資料,需要的朋友可以參考下2016-09-09Java實(shí)現(xiàn)雙鏈表互相交換任意兩個(gè)節(jié)點(diǎn)的方法示例
這篇文章主要介紹了Java實(shí)現(xiàn)雙鏈表互相交換任意兩個(gè)節(jié)點(diǎn)的方法,簡(jiǎn)單講述了雙鏈表的概念,并結(jié)合實(shí)例形式給出了java雙鏈表實(shí)現(xiàn)任意兩個(gè)節(jié)點(diǎn)交換的操作技巧,需要的朋友可以參考下2017-11-11JAVA 16位ID生成工具類含16位不重復(fù)的隨機(jī)數(shù)數(shù)字+大小寫
這篇文章主要介紹了JAVA 16位ID生成工具類含16位不重復(fù)的隨機(jī)數(shù)數(shù)字+大小寫,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-02-02Java Lambda表達(dá)式原理及多線程實(shí)現(xiàn)
這篇文章主要介紹了Java Lambda表達(dá)式原理及多線程實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-07-07