最简单的SpringBoot+MyBatis多数据源实现
创始人
2024-05-29 12:12:18
0

最简单的SpringBoot+MyBatis多数据源实现

    • 1.数据库准备
    • 2.环境准备
    • 3.代码部分
      • 3.1多数据源配置
      • 2.测试

image-20200708160944615

随着应用用户数量的增加,相应的并发请求的数量也会跟着不断增加,慢慢地,单个数据库已经没有办法满足频繁的数据库操作请求了,在某些场景下,可能会需要配置多个数据源,使用多个数据源(例如实现数据库的读写分离)来缓解系统的压力等,同样的,Springboot官方提供了相应的实现来帮助开发者们配置多数据源,一般分为两种方式(目前所了解到的),分包和AOP。

考虑到mybatis是java开发使用较为频繁的数据库框架,所以使用Springboot+Mybatis来实现多数据源的配置。

1.数据库准备

既然是配置多数据源,那么自然就要先把相应的数据源给准备好,本地新建了两个数据库,如下表:

数据库数据表字段
testdatasource1sys_useruser_id(int), user_name(varchar) user_age(int)
testdatasource2sys_user2同上

并分别插入两条记录,为了方便对比,其中testdatasource1为芳年25岁的张三, testdatasource2为芳年30岁的李四。

2.环境准备

首先新建一个Springboot项目,这里版本是2.1.7.RELEASE,并在pom文件中引入相关依赖:关键依赖如下:

org.mybatis.spring.bootmybatis-spring-boot-starter1.3.2
mysqlmysql-connector-java

3.代码部分

3.1多数据源配置

首先呢,在Springboot的配置文件中配置的datasourse,和以往不一样的是,因为有两个数据源,所以要指定相关数据库的名称,其中主数据源为primary,次数据源为secondary如下:

#配置主数据库
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##配置次数据库
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.Driverspring.http.encoding.charset=UTF-8
spring.http.encoding.enabled=true
spring.http.encoding.force=true

需要注意的是,Springboot2.0 在配置数据库连接的时候需要使用jdbc-url,如果只使用url的话会报
jdbcUrl is required with driverClassName.错误。

新建一个配置类PrimaryDataSourceConfig,用于配置的主数据库相关的bean,代码如下:

@Configuration
//basePackages:接口文件的包路径
@MapperScan(basePackages = "com.jdkcb.mybatisstuday.mapper.one", sqlSessionFactoryRef = "PrimarySqlSessionFactory")
public class PrimaryDataSourceConfig {@Bean(name = "PrimaryDataSource")// 表示这个数据源是默认数据源@Primary//这个一定要加,如果两个数据源都没有@Primary会报错@ConfigurationProperties(prefix = "spring.datasource.primary")//配置文件中的前缀public DataSource getPrimaryDateSource() {return DataSourceBuilder.create().build();}@Bean(name = "PrimarySqlSessionFactory")@Primarypublic 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();// 设置mybatis的xml所在位置}@Bean("PrimarySqlSessionTemplate")// 表示这个数据源是默认数据源@Primarypublic SqlSessionTemplate primarySqlSessionTemplate(@Qualifier("PrimarySqlSessionFactory") SqlSessionFactory sessionfactory) {return new SqlSessionTemplate(sessionfactory);}}

注解说明:

@MapperScan :配置mybatis的接口类放的地方

@Primary :表示使用的是默认数据库,这个一个要加,否则会因为不知道哪个数据库是默认数据库而报错

@ConfigurationProperties:读取application.properties中的配置参数映射成为一个对象,其中prefix表示参数的前缀

大功告成~ ~ 了吗?并没有,然后配置的第二个数据源的配置类,代码如下:

@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();// 设置mybatis的xml所在位置}@Bean("SecondarySqlSessionTemplate")public SqlSessionTemplate secondarySqlSessionTemplate(@Qualifier("SecondarySqlSessionFactory") SqlSessionFactory sessionfactory) {return new SqlSessionTemplate(sessionfactory);}

剩下的就是编写相应的xml文件和接口类了,代码如下:

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

相关的xml文件如下:







注:其中xml文件在本实例中目录为:resources/mapping

2.测试

编写一个Controller用于测试,因为是测试实例且代码相对来说较为简单,所以这里就不写Service层了。

代码如下:

@RestController
public class UserController {@Autowiredprivate PrimaryUserMapper primaryUserMapper;@Autowiredprivate SecondaryUserMapper secondaryUserMapper;@RequestMapping("/primary")public Object primary(){List list = primaryUserMapper.findAll();return list;}@RequestMapping("/secondary")public Object secondary  (){List list = secondaryUserMapper.findAll();return list;}}

在浏览器分别输入:http://127.0.0.1:8080/primary 和 http://127.0.0.1:8080/secondary

结果如下:

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

相关内容

热门资讯

php程序员个人简历 php程序员个人简历  简历是有针对性的自我介绍的一种规范化、逻辑化的书面表达。对应聘者来说,简历是...
业务员个人简历 业务员个人简历模板  简历中切忌虚构或者隐瞒自己的任职岗位、任职企业、任职时间、学历等重要要素。下面...
会计简历英语翻译 主要从事登记凭证,账簿,发票1.根据所提供的经济业务及原始凭证,整理或填制有关经济业务的原始凭证,分...
农信社个人简历范文优选18篇 农信社个人简历范文 第一篇尊敬的领导:您好!我是xx职业技术学院财会专业的大专毕业生,现在读xx广播...
关于毕业生的英文简历   Objective  To obtain a challenging position as a...
简历上哪些内容不能写   一、 离婚  常常会见到这样有趣的现象,求职者在简历上无心写上的一些字句,如“婚姻状况:离婚”等...
韵味圆形简历封面   这是小编搜集的一个韵味圆形简历封面,欢迎浏览。  附:简历模板是个人简历的框架,也是招聘人员在浏...
电子简历如何制作 电子简历模板如何制作(通用6篇)  人生天地之间,若白驹过隙,忽然而已,新一轮的招聘又在朝我们招手,...
飞机维修员助理简历范文优选7... 飞机维修员助理简历范文 第一篇基本信息姓 名:李某某性别:男民族:汉政治面貌:团员户籍:北京出生年月...
英文简历:应聘跨国酒店的文职... 英文简历:应聘跨国酒店的文职人员Resume of Junjun Du        No.29 B...
个人工作简历 个人工作简历模板范文  一份好的简历是敲开公司的开门砖,那么如何写一份亮眼的简历呢?下面小编整理了关...
简历里一句话介绍自己   如何用一句话介绍自己?客观分析自己的优缺点,用最简明扼要的字句展示你的卖点!下面小编为大家带来了...
应聘大学社团简历范文共17篇 应聘大学社团简历范文 第一篇自我评价:本人性格开朗、稳重、有活力,待人热情、真诚。工作认真负责,积极...
关于护士招聘的简历模板   导语:简历,顾名思义,就是对个人学历、经历、特长、爱好及其它有关情况所作的简明扼要的书面介绍。简...
机械与仪表自动化专业简历 机械与仪表自动化专业简历范文  据相关调查显示,多数用人单位在个人简历的筛选上,都只是看一些硬性的指...
个人应聘简历表格   应聘的时候怎样的简历表格才受欢迎?下面是CN人才网小编整理的个人应聘简历表格,欢迎浏览。个人基本...
医学生个人简历模板下载wor...   基本信息  姓名:简历下载  国籍:中国  目前所在地: 广州  民族: 汉族  户口所在地: ...
小升初简历:如何让自我介绍为... 自我介绍是小升初简历的开场白,如何让小升初简历中的自我介绍为自己加分呢?小升初资深专家认为写小升初的...
正规个人简历 2017正规个人简历模板范文  适宜在个人简历里出现的活动最好的就是拥有专业性色彩,至于专业可和应聘...
优秀版求职简历 优秀版求职简历模板  光阴的迅速,一眨眼就过去了,又到了寻求新的工作机会的时候,这时一份好的简历可以...