日日操夜夜添-日日操影院-日日草夜夜操-日日干干-精品一区二区三区波多野结衣-精品一区二区三区高清免费不卡

公告:魔扣目錄網(wǎng)為廣大站長(zhǎng)提供免費(fèi)收錄網(wǎng)站服務(wù),提交前請(qǐng)做好本站友鏈:【 網(wǎng)站目錄:http://www.ylptlb.cn 】, 免友鏈快審服務(wù)(50元/站),

點(diǎn)擊這里在線咨詢客服
新站提交
  • 網(wǎng)站:51998
  • 待審:31
  • 小程序:12
  • 文章:1030137
  • 會(huì)員:747

01 前言

隨著應(yīng)用用戶數(shù)量的增加,相應(yīng)的并發(fā)請(qǐng)求的數(shù)量也會(huì)跟著不斷增加,慢慢地,單個(gè)數(shù)據(jù)庫(kù)已經(jīng)沒(méi)有辦法滿足我們頻繁的數(shù)據(jù)庫(kù)操作請(qǐng)求了,在某些場(chǎng)景下,我們可能會(huì)需要配置多個(gè)數(shù)據(jù)源,使用多個(gè)數(shù)據(jù)源(例如實(shí)現(xiàn)數(shù)據(jù)庫(kù)的讀寫(xiě)分離)來(lái)緩解系統(tǒng)的壓力等,同樣的,Springboot官方提供了相應(yīng)的實(shí)現(xiàn)來(lái)幫助開(kāi)發(fā)者們配置多數(shù)據(jù)源,一般分為兩種方式(目前我所了解到的),分包和AOP,其中利用AOP實(shí)現(xiàn)多個(gè)數(shù)據(jù)源到的動(dòng)態(tài)切換時(shí)候會(huì)另開(kāi)一篇文章來(lái)寫(xiě)。考慮到MyBatis是JAVA開(kāi)發(fā)者們使用較為頻繁的數(shù)據(jù)庫(kù)框架,所以本篇文章使用Springboot+Mybatis來(lái)實(shí)現(xiàn)多數(shù)據(jù)源的配置。

廢話不多說(shuō),走起。

 

02 數(shù)據(jù)庫(kù)準(zhǔn)備

既然是配置多數(shù)據(jù)源,那么我們自然就要先把相應(yīng)的數(shù)據(jù)源給準(zhǔn)備好,這里呢,我本地新建了兩個(gè)數(shù)據(jù)庫(kù),如下表:

Springboot +Mybatis實(shí)現(xiàn)多數(shù)據(jù)源配置,你會(huì)嗎?

 

并分別插入兩條記錄,為了方便對(duì)比,其中testdatasource1為芳年25歲的張三, testdatasource2為芳年30歲的李四。

03 環(huán)境準(zhǔn)備

首先新建一個(gè)Springboot項(xiàng)目,我這里版本是2.1.7.RELEASE,并在pom文件中引入相關(guān)依賴:關(guān)鍵依賴如下:

 <dependency>
 <groupId>org.mybatis.spring.boot</groupId>
 <artifactId>mybatis-spring-boot-starter</artifactId>
 <version>1.3.2</version>
 </dependency>
 <dependency>
 <groupId>MySQL</groupId>
 <artifactId>mysql-connector-java</artifactId>
 </dependency>

到這里我們的環(huán)境已經(jīng)基本配置完成了。

04 代碼部分

4.1 多數(shù)據(jù)源配置

首先呢,在我們Springboot的配置文件中配置我們的datasourse,和以往不一樣的是,因?yàn)槲覀冇袃蓚€(gè)數(shù)據(jù)源,所以要指定相關(guān)數(shù)據(jù)庫(kù)的名稱,其中主數(shù)據(jù)源為primary,次數(shù)據(jù)源為secondary如下:

#配置主數(shù)據(jù)庫(kù)
spring.datasource.primary.jdbc-url=jdbc:mysql://localhost:3306/testdatasource1?useUnicode=true&characterEncoding=UTF-8&serverTimezone=UTC&useSSL=false
spring.datasource.primary.username=root
spring.datasource.primary.password=root
spring.datasource.primary.driver-class-name=com.mysql.cj.jdbc.Driver
##配置次數(shù)據(jù)庫(kù)
spring.datasource.secondary.jdbc-url=jdbc:mysql://localhost:3306/testdatasource2?useUnicode=true&characterEncoding=UTF-8&serverTimezone=UTC&useSSL=false
spring.datasource.secondary.username=root
spring.datasource.secondary.password=root
spring.datasource.secondary.driver-class-name=com.mysql.cj.jdbc.Driver
spring.http.encoding.charset=UTF-8
spring.http.encoding.enabled=true
spring.http.encoding.force=true

需要我們注意的是,Springboot2.0 在配置數(shù)據(jù)庫(kù)連接的時(shí)候需要使用jdbc-url,如果只使用url的話會(huì)報(bào)

jdbcUrl is required with driverClassName.錯(cuò)誤。

新建一個(gè)配置類(lèi)PrimaryDataSourceConfig,用于配置我們的主數(shù)據(jù)庫(kù)相關(guān)的bean,代碼如下:

@Configuration
@MApperScan(basePackages = "com.jdkcb.mybatisstuday.mapper.one", sqlSessionFactoryRef = "PrimarySqlSessionFactory")//basePackages:接口文件的包路徑
public class PrimaryDataSourceConfig {
 @Bean(name = "PrimaryDataSource")
 // 表示這個(gè)數(shù)據(jù)源是默認(rèn)數(shù)據(jù)源
 @Primary//這個(gè)一定要加,如果兩個(gè)數(shù)據(jù)源都沒(méi)有@Primary會(huì)報(bào)錯(cuò)
 @ConfigurationProperties(prefix = "spring.datasource.primary")//我們配置文件中的前綴
 public DataSource getPrimaryDateSource() {
 return DataSourceBuilder.create().build();
 }
 @Bean(name = "PrimarySqlSessionFactory")
 @Primary
 public SqlSessionFactory primarySqlSessionFactory(@Qualifier("PrimaryDataSource") DataSource datasource)
 throws Exception {
 SqlSessionFactoryBean bean = new SqlSessionFactoryBean();
 bean.setDataSource(datasource);
 bean.setMapperLocations( 
 new PathMatchingResourcePatternResolver().getResources("classpath*:mapping/one/*.xml"));
 return bean.getObject();// 設(shè)置mybatis的xml所在位置
 }
 
 
 @Bean("PrimarySqlSessionTemplate")
 // 表示這個(gè)數(shù)據(jù)源是默認(rèn)數(shù)據(jù)源
 @Primary
 public SqlSessionTemplate primarySqlSessionTemplate(
 @Qualifier("PrimarySqlSessionFactory") SqlSessionFactory sessionfactory) {
 return new SqlSessionTemplate(sessionfactory);
 }
}

注解說(shuō)明:

@MapperScan :配置mybatis的接口類(lèi)放的地方

@Primary :表示使用的是默認(rèn)數(shù)據(jù)庫(kù),這個(gè)一個(gè)要加,否則會(huì)因?yàn)椴恢滥膫€(gè)數(shù)據(jù)庫(kù)是默認(rèn)數(shù)據(jù)庫(kù)而報(bào)錯(cuò)

@ConfigurationProperties:讀取application.properties中的配置參數(shù)映射成為一個(gè)對(duì)象,其中prefix表示參數(shù)的前綴

大功告成~ ~ 了嗎?并沒(méi)有,然后配置我們的第二個(gè)數(shù)據(jù)源的配置類(lèi),代碼如下:

@Configuration
@MapperScan(basePackages = "com.jdkcb.mybatisstuday.mapper.two", sqlSessionFactoryRef = "SecondarySqlSessionFactory")
public class SecondaryDataSourceConfig {
 @Bean(name = "SecondaryDataSource")
 @ConfigurationProperties(prefix = "spring.datasource.secondary")
 public DataSource getSecondaryDataSource() {
 return DataSourceBuilder.create().build();
 }
 @Bean(name = "SecondarySqlSessionFactory")
 public SqlSessionFactory secondarySqlSessionFactory(@Qualifier("SecondaryDataSource") DataSource datasource)
 throws Exception {
 SqlSessionFactoryBean bean = new SqlSessionFactoryBean();
 bean.setDataSource(datasource);
 bean.setMapperLocations(
 new PathMatchingResourcePatternResolver().getResources("classpath*:mapping/two/*.xml"));
 return bean.getObject();// 設(shè)置mybatis的xml所在位置
 }
 @Bean("SecondarySqlSessionTemplate")
 public SqlSessionTemplate secondarySqlSessionTemplate(
 @Qualifier("SecondarySqlSessionFactory") SqlSessionFactory sessionfactory) {
 return new SqlSessionTemplate(sessionfactory);
 }

剩下的就是編寫(xiě)我們相應(yīng)的xml文件和接口類(lèi)了,代碼如下:

@Component
@Mapper
public interface PrimaryUserMapper {
 List<User> findAll();
}
@Component
@Mapper
public interface SecondaryUserMapper {
 List<User> findAll();
}

相關(guān)的xml文件如下:

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
 PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
 "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.jdkcb.mybatisstuday.mapper.one.PrimaryUserMapper">
 <select id="findAll" resultType="com.jdkcb.mybatisstuday.pojo.User">
 select * from sys_user;
 </select>
</mapper>
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
 PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
 "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.jdkcb.mybatisstuday.mapper.two.SecondaryUserMapper">
 <select id="findAll" resultType="com.jdkcb.mybatisstuday.pojo.User">
 select * from sys_user2;
 </select>
</mapper>

注:其中xml文件在本實(shí)例中目錄為:resources/mapping

4.2 測(cè)試

編寫(xiě)一個(gè)Controller用于測(cè)試,因?yàn)槭菧y(cè)試實(shí)例且代碼相對(duì)來(lái)說(shuō)較為簡(jiǎn)單,所以這里就不寫(xiě)Service層了。

代碼如下:

@RestController
public class UserController {
 @Autowired
 private PrimaryUserMapper primaryUserMapper;
 @Autowired
 private SecondaryUserMapper secondaryUserMapper;
 @RequestMapping("primary")
 public Object primary(){
 List<User> list = primaryUserMapper.findAll();
 return list;
 }
 @RequestMapping("secondary")
 public Object secondary (){
 List<User> list = secondaryUserMapper.findAll();
 return list;
 }
 
}

在瀏覽器分別輸入
:http://127.0.0.1:8080/primary 和
http://127.0.0.1:8080/secondary

結(jié)果如下:

[{"user_id":1,"user_name":"張三","user_age":25}] //primary 
[{"user_id":1,"user_name":"李四","user_age":30}] //secondary

到此,Springboot結(jié)合mybatis配置多數(shù)據(jù)源就大功告成啦。

好啦,看完之后如果你覺(jué)得有所收獲,那就點(diǎn)個(gè)贊再走唄~

分享到:
標(biāo)簽:Mybatis
用戶無(wú)頭像

網(wǎng)友整理

注冊(cè)時(shí)間:

網(wǎng)站:5 個(gè)   小程序:0 個(gè)  文章:12 篇

  • 51998

    網(wǎng)站

  • 12

    小程序

  • 1030137

    文章

  • 747

    會(huì)員

趕快注冊(cè)賬號(hào),推廣您的網(wǎng)站吧!
最新入駐小程序

數(shù)獨(dú)大挑戰(zhàn)2018-06-03

數(shù)獨(dú)一種數(shù)學(xué)游戲,玩家需要根據(jù)9

答題星2018-06-03

您可以通過(guò)答題星輕松地創(chuàng)建試卷

全階人生考試2018-06-03

各種考試題,題庫(kù),初中,高中,大學(xué)四六

運(yùn)動(dòng)步數(shù)有氧達(dá)人2018-06-03

記錄運(yùn)動(dòng)步數(shù),積累氧氣值。還可偷

每日養(yǎng)生app2018-06-03

每日養(yǎng)生,天天健康

體育訓(xùn)練成績(jī)?cè)u(píng)定2018-06-03

通用課目體育訓(xùn)練成績(jī)?cè)u(píng)定