一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|JAVA教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|JavaScript|易語言|

服務器之家 - 編程語言 - JAVA教程 - Spring Boot 整合mybatis 使用多數據源的實現方法

Spring Boot 整合mybatis 使用多數據源的實現方法

2021-04-09 11:34互扯程序 JAVA教程

這篇文章主要介紹了Spring Boot 整合mybatis 使用多數據源的實現方法,需要的朋友可以參考下

前言

本篇教程偏向實戰,程序猿直接copy代碼加入到自己的項目中做簡單的修修改改便可使用,而對于springboot以及mybatis不在此進行展開介紹,如有讀者希望了解可以給我留言,并持續關注,我后續會慢慢更新。(黑色區域代碼部分,安卓手機可手動向左滑動,來查看全部代碼)

整合

其實整合很簡單,如果是用gradle的話,在build.gradle文件里加入

?
1
compile('org.mybatis.spring.boot:mybatis-spring-boot-starter:1.3.1')

如果是用maven的話在pom.xml文件里加入

Spring Boot 整合mybatis 使用多數據源的實現方法

單庫配置:

引入之后,默認情況下,spring boot會自動為我們配置好一個datasource,它會在classpath中搜索h2、hsqldb等內存數據庫的jar包,如果找到了,就會自動配置一個內存數據庫的datasource。

如果在application.yml或application.property中指定了spring.datasource.*的相關配置參數,spring boot就會使用該配置創建一個datasource。

然后會自動創建使用該datasource的sqlsessionfactorybean以及sqlsessiontemplate。會自動掃描你的mappers,連接到sqlsessiontemplate,并注冊到spring上下文中。

?
1
2
3
4
spring.datasource.url=jdbc:mysql://localhost/test
spring.datasource.username=dbuser
spring.datasource.password=dbpass
spring.datasource.driver-class-name=com.mysql.jdbc.driver

更多參數請查看datasourceproperties

多庫配置:

由于業務需要,項目要同時使用多個數據庫進行業務開發:

首先,我們必須在application.property中自定義兩個數據源的配置,一個使用first.datasource.*,另一個使用second.datasource.*,為了能使別人一眼看出連接的是什么庫,可以使用數據庫命名,比如user庫,則可以使用user.datasource.*,在使用多數據源的時候,所有必要配置都不能省略。

?
1
2
3
4
5
6
7
8
9
10
first.datasource.url=jdbc:mysql://localhost/first
first.datasource.username=dbuser1
first.datasource.password=dbpass1
first.datasource.driver-class-name=com.mysql.jdbc.driver
first.datasource.type=com.alibaba.druid.pool.druiddatasource//我用的是druid,也可以不加用默認的
second.datasource.url=jdbc:mysql://localhost/second
second.datasource.username=dbuser2
second.datasource.password=dbpass2
second.datasource.driver-class-name=com.mysql.jdbc.driver
second.datasource.type=com.alibaba.druid.pool.druiddatasource

直接上代碼,我的做法是將兩個數據源用兩個配置類創建:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
@configuration
@mapperscan(basepackages = {"com.user.server.dao"}, sqlsessiontemplateref = "usersqlsessiontemplate")
public class usermybatisconfig {
 @bean(name = "userdatasource")
 @primary //必須加此注解,不然報錯,下一個類則不需要添加
 @configurationproperties(prefix = "first.datasource") // prefix值必須是application.properteis中對應屬性的前綴
 public datasource userdatasource() {
  return datasourcebuilder.create().build();
 }
 @bean
 public sqlsessionfactory usersqlsessionfactory(@qualifier("userdatasource") datasource datasource) throws exception {
  sqlsessionfactorybean bean = new sqlsessionfactorybean();
  bean.setdatasource(datasource);
  //添加xml目錄
  resourcepatternresolver resolver = new pathmatchingresourcepatternresolver();
 try {
   bean.setmapperlocations(resolver.getresources("classpath*:com/user/server/dao/mapping/*.xml"));
   return bean.getobject();
  } catch (exception e) {
   e.printstacktrace();
   throw new runtimeexception(e);
  }
 }
 @bean
 public sqlsessiontemplate usersqlsessiontemplate(@qualifier("usersqlsessionfactory") sqlsessionfactory sqlsessionfactory) throws exception {
  sqlsessiontemplate template = new sqlsessiontemplate(sqlsessionfactory); // 使用上面配置的factory
  return template;
 }
}
@configuration
@mapperscan(basepackages = {"com.airmi.server.dao"}, sqlsessiontemplateref = "autotestsqlsessiontemplate")
 public class autotestmybatisconfig {
  @bean
  @configurationproperties(prefix = "autotest.datasource")
   public datasource autotestdatasource() {
   return datasourcebuilder.create().build();
  }
  @bean
  public sqlsessiontemplate autotestsqlsessiontemplate(@qualifier("autotestsqlsessionfactory") sqlsessionfactory sqlsessionfactory) throws exception {
   sqlsessiontemplate template = new sqlsessiontemplate(sqlsessionfactory);
    return template;
   }
  @bean
  public sqlsessionfactory autotestsqlsessionfactory(@qualifier("autotestdatasource") datasource datasource) throws exception {
   sqlsessionfactorybean bean = new sqlsessionfactorybean();
   bean.setdatasource(datasource);
   //添加xml目錄
   resourcepatternresolver resolver = new pathmatchingresourcepatternresolver();
   try {
    bean.setmapperlocations(resolver.getresources("classpath*:com/airmi/server/dao/mapping/*.xml"));
    return bean.getobject();
   } catch (exception e) {
    e.printstacktrace();
    throw new runtimeexception(e);
   }
  }
 }

 @primary //該注解表示在同一個接口有多個實現類可以注入的時候,默認選擇哪一個,而不是讓autowire注解報錯,官網要求當多個數據源時,必須指定一個datasource,另一個datasource則不用添加。

@qualifier 根據名稱進行注入,通常是在具有相同的多個類型的實例的一個注入(例如有多個datasource類型的實例)。

?
1
@mapperscan (basepackages = {"com.user.server.dao"}, sqlsessiontemplateref = "usersqlsessiontemplate") basepackages為mapper所在的包,sqlsessiontemplateref要引用的實例。

user代碼結構如下:

Spring Boot 整合mybatis 使用多數據源的實現方法

總結

以上所述是小編給大家介紹的spring boot 整合mybatis 使用多數據源的實現方法,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對服務器之家網站的支持!

原文鏈接:https://www.jianshu.com/p/0fb2bad454e4

延伸 · 閱讀

精彩推薦
  • JAVA教程java讀取文件和寫入文件的方式(簡單實例)

    java讀取文件和寫入文件的方式(簡單實例)

    下面小編就為大家帶來一篇java讀取文件和寫入文件的方式(簡單實例)。小編覺得挺不錯的,現在就分享給大家,也給大家做個參考。一起跟隨小編過來看看...

    jingxian9572020-06-28
  • JAVA教程Jmeter多種定時器實現方法解析

    Jmeter多種定時器實現方法解析

    這篇文章主要介紹了Jmeter多種定時器實現方法解析,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參...

    多測師_鄭sir1552020-09-08
  • JAVA教程springmvc4+hibernate4分頁查詢功能實現

    springmvc4+hibernate4分頁查詢功能實現

    本篇文章主要介紹了springmvc4+hibernate4分頁查詢功能實現,Springmvc+hibernate成為現在很多人用的框架整合,有興趣的可以了解一下。 ...

    虞秀權1342020-07-23
  • JAVA教程java8版本base64加密解密的實例

    java8版本base64加密解密的實例

    下面小編就為大家分享一篇java8版本base64加密解密的實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧...

    流浪少年11472021-03-06
  • JAVA教程Mybatis Update操作返回值問題

    Mybatis Update操作返回值問題

    在獲取update操作的返回值時遇到了一個問題,似乎 Mybatis 進行 update 操作得到的 int 返回值并不是影響的行數,下面通過本文給大家分享Mybatis Update操作返回...

    tuicool4482020-12-29
  • JAVA教程Java設計模式之策略模式詳解

    Java設計模式之策略模式詳解

    這篇文章主要為大家詳細介紹了Java設計模式之策略模式,具有一定的參考價值,感興趣的小伙伴們可以參考一下...

    溫柔狠角色2342020-06-27
  • JAVA教程Java泛型之上界下界通配符詳解

    Java泛型之上界下界通配符詳解

    這篇文章主要介紹了Java泛型之上界下界通配符詳解,學習使用泛型編程時,更令人困惑的一個方面是確定何時使用上限有界通配符以及何時使用下限有界通...

    JAVA專欄4982021-04-05
  • JAVA教程淺談Java實體對象的三種狀態以及轉換關系

    淺談Java實體對象的三種狀態以及轉換關系

    這篇文章主要介紹了淺談Java實體對象的三種狀態以及轉換關系,具有一定參考價值,需要的朋友可以,看看。。...

    ^_^7602021-02-01
主站蜘蛛池模板: zol中关村在线官网 yy6080欧美三级理论 | 不知火舞被c视频在线播放 不卡一区二区三区卡 | 青青成人在线 | 亚洲天堂影院在线观看 | 国产成人精品一区二区 | 精品淑女少妇AV久久免费 | 国产亚洲精品美女2020久久 | 香蕉国产精品偷在线播放 | katsuniav在线播放 | 亚洲国产日韩欧美在线vip1区 | 91精品乱码一区二区三区 | 极品美女aⅴ高清在线观看 极品ts赵恩静和直男激战啪啪 | www.87福利 | 男人晚上看的 | 男女发生性关系视频 | 天天快乐在线观看 | 草久社区 | 四虎综合九九色九九综合色 | 欧美综合另类 | 国产精品吹潮香蕉在线观看 | 国产婷婷高清在线观看免费 | 黄色大片三级 | 午夜亚洲国产 | blacked最大的吊 | 色一情一区二区三区四区 | 恩爱夫妇交换小说 | 亚洲剧情在线观看 | 禁漫H天堂免费A漫 | 国产巨大bbbb俄罗斯 | 我半夜摸妺妺的奶C了她 | 国产剧情麻豆刘玥视频 | 久久精品黄AA片一区二区三区 | 国产亚洲女人久久久久久 | 亚洲va欧美va国产va天堂影 | 精品免费国产一区二区三区 | 欧美一区二区福利视频 | 亲爱的客栈第二季免费观看完整版 | 十大看黄网站 | 免费在线观看视频 | 校园刺激全黄H全肉细节文 校草让我脱了内裤给全班看 | 国产精品2|