服务器之家:专注于服务器技术及软件下载分享
分类导航

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