当前位置: 首页 > news >正文

springboot,mysql多数据源-mybaits

为啥要多数据源,因为我现在有个需求,需要将A库的查询结果,写入到B库。

但是原来的springboot里面就只有A库,所以现在要加上B库。


1.修改application.yaml的数据库连接

这个是原来的

现在改成

其实就是将datasource:xxx,改成了datasource:aku:xxx 然后【同级】加了一个bku:xxx。

还有要把url改成jdbc-url 。application的datasource下的url要换成jdbc-url。多数据的话必须换成这个

2.在resource的mapper里创建2个mapper文件夹

将原来默认的mapper下的,内容放到aku下,此时发现变灰,因为mapper路径被改了,下一步会重新配置映射

java代码包mapper的包里,也【创建】2个package

同样,把原来mapper的interface的java文件复制到aku里。

3.修改application.yaml的mybaits配置,重新配置映射

注意红色部分是我新加的,这样就重新映射上了

mybatis:mapper-locations: classpath:/mapper/**/*.xmlconfiguration:map-underscore-to-camel-case: true

4.创建2个源连接,主库和从库的

以前是不需要配置的,因为会走默认配置,现在有2个了,你就得写2个,并且告诉他们对应的mapper是哪个。

随便找个文件夹创建一下,我在我自己的config里面创建下面2个程序

AkuDataSourceConfig

package com.example.demo.config;import org.apache.ibatis.session.SqlSessionFactory;
import org.mybatis.spring.SqlSessionFactoryBean;
import org.mybatis.spring.annotation.MapperScan;
import org.springframework.beans.factory.annotation.Qualifier;
import org.springframework.boot.context.properties.ConfigurationProperties;
import org.springframework.boot.jdbc.DataSourceBuilder;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.context.annotation.Primary;
import org.springframework.core.io.Resource;
import org.springframework.core.io.support.PathMatchingResourcePatternResolver;
import org.springframework.jdbc.datasource.DataSourceTransactionManager;import javax.sql.DataSource;
@Configuration
@MapperScan(basePackages = "com.example.demo.mapper.aku", sqlSessionFactoryRef = "masterSqlSessionFactory")
public class AkuDataSourceConfig {@Primary@Bean("masterDataSource")@ConfigurationProperties(prefix = "spring.datasource.master")public DataSource masterDataSource() {return DataSourceBuilder.create().build();}@Primary@Bean("masterDataSourceTransactionManager")public DataSourceTransactionManager masterDataSourceTransactionManager(@Qualifier("masterDataSource") DataSource dataSource) {return new DataSourceTransactionManager(dataSource);}@Primary@Bean("masterSqlSessionFactory")public SqlSessionFactory masterSqlSessionFactory(@Qualifier("masterDataSource") DataSource dataSource) throws Exception {SqlSessionFactoryBean sqlSessionFactory = new SqlSessionFactoryBean();sqlSessionFactory.setDataSource(dataSource);Resource[] resources = new PathMatchingResourcePatternResolver().getResources("classpath:mapper/aku/*.xml");sqlSessionFactory.setMapperLocations(resources);return sqlSessionFactory.getObject();}}
只用注意这3个地方改一下,标红的,分别对应的是interface,mapper.xml还有application.yaml@MapperScan(basePackages = "com.example.demo.mapper.aku", sqlSessionFactoryRef = "masterSqlSessionFactory")
PathMatchingResourcePatternResolver().getResources("classpath:mapper/aku/*.xml");
@ConfigurationProperties(prefix = "spring.datasource.aku")

BkuDataSourceConfig

package com.example.demo.config;import org.apache.ibatis.session.SqlSessionFactory;
import org.mybatis.spring.SqlSessionFactoryBean;
import org.mybatis.spring.annotation.MapperScan;
import org.springframework.beans.factory.annotation.Qualifier;
import org.springframework.boot.context.properties.ConfigurationProperties;
import org.springframework.boot.jdbc.DataSourceBuilder;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.context.annotation.Primary;
import org.springframework.core.io.Resource;
import org.springframework.core.io.support.PathMatchingResourcePatternResolver;
import org.springframework.jdbc.datasource.DataSourceTransactionManager;import javax.sql.DataSource;@Configuration
@MapperScan(basePackages = "com.example.demo.mapper.bku", sqlSessionFactoryRef = "slaveSqlSessionFactory")
public class BkuDataSourceConfig {@Bean("slaveDataSource")@ConfigurationProperties(prefix = "spring.datasource.slave")public DataSource slaveDataSource() {return DataSourceBuilder.create().build();}@Bean("slaveDataSourceTransactionManager")public DataSourceTransactionManager slaveDataSourceTransactionManager(@Qualifier("slaveDataSource") DataSource dataSource) {return new DataSourceTransactionManager(dataSource);}@Bean("slaveSqlSessionFactory")public SqlSessionFactory slaveSqlSessionFactory(@Qualifier("slaveDataSource") DataSource dataSource) throws Exception {SqlSessionFactoryBean sqlSessionFactory = new SqlSessionFactoryBean();sqlSessionFactory.setDataSource(dataSource);Resource[] resources = new PathMatchingResourcePatternResolver().getResources("classpath:mapper/bku/*.xml");sqlSessionFactory.setMapperLocations(resources);return sqlSessionFactory.getObject();}}

b库复制这段代码后,需要改的也是类似a库标红的地方。

5.启动测试

成功

用的时候导入不同的mapper,就可以了。

参考:Spring Boot整合MyBatis配置多数据源-CSDN博客

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • idea和jdk的安装教程
  • Qt QCustomPlot 图形库详解
  • 代码随想录算法训练营第三十天|查找重叠区间、划分字母区间
  • 自动化测试必会之数据驱动测试
  • 【数据结构和算法】时间复杂度和空间复杂度
  • springBoot框架
  • 守护数字堡垒:全面掌握安全配置管理
  • 什么是令牌桶算法?工作原理是什么?使用它有哪些优点和注意事项?
  • C++ | 深入理解C++的IO流:从控制台输出流到文件输出流的应用
  • LeetCode面试题Day8|LeetCode13 罗马数字转整数、LeetCode12 整数转罗马数字
  • Events and the Kernel
  • HarmonyOS NEXT星河版零基础入门(2)
  • 3-2 光敏电阻(智能应用篇)
  • 构建坚不可摧的防线:全面指南到高效信息安全管理体系
  • 力扣第五十六题——合并区间
  • ES6指北【2】—— 箭头函数
  • 《Javascript高级程序设计 (第三版)》第五章 引用类型
  • 2018以太坊智能合约编程语言solidity的最佳IDEs
  • Git的一些常用操作
  • Golang-长连接-状态推送
  • HTTP 简介
  • JavaScript 无符号位移运算符 三个大于号 的使用方法
  • JS 面试题总结
  • Laravel 实践之路: 数据库迁移与数据填充
  • 从重复到重用
  • 构建二叉树进行数值数组的去重及优化
  • 名企6年Java程序员的工作总结,写给在迷茫中的你!
  • 使用阿里云发布分布式网站,开发时候应该注意什么?
  • 适配iPhoneX、iPhoneXs、iPhoneXs Max、iPhoneXr 屏幕尺寸及安全区域
  • 携程小程序初体验
  • 一些关于Rust在2019年的思考
  • 在Docker Swarm上部署Apache Storm:第1部分
  • 找一份好的前端工作,起点很重要
  • 3月7日云栖精选夜读 | RSA 2019安全大会:企业资产管理成行业新风向标,云上安全占绝对优势 ...
  • ​zookeeper集群配置与启动
  • ​水经微图Web1.5.0版即将上线
  • ​云纳万物 · 数皆有言|2021 七牛云战略发布会启幕,邀您赴约
  • # 深度解析 Socket 与 WebSocket:原理、区别与应用
  • (6)STL算法之转换
  • (day 2)JavaScript学习笔记(基础之变量、常量和注释)
  • (补充):java各种进制、原码、反码、补码和文本、图像、音频在计算机中的存储方式
  • (附源码)springboot 校园学生兼职系统 毕业设计 742122
  • (附源码)ssm码农论坛 毕业设计 231126
  • (论文阅读40-45)图像描述1
  • (三)模仿学习-Action数据的模仿
  • (一)Java算法:二分查找
  • **《Linux/Unix系统编程手册》读书笔记24章**
  • .bat批处理(十):从路径字符串中截取盘符、文件名、后缀名等信息
  • .bat批处理(四):路径相关%cd%和%~dp0的区别
  • .Net Redis的秒杀Dome和异步执行
  • .net 调用php,php 调用.net com组件 --
  • .netcore 获取appsettings
  • //TODO 注释的作用
  • //usr/lib/libgdal.so.20:对‘sqlite3_column_table_name’未定义的引用
  • /dev/VolGroup00/LogVol00:unexpected inconsistency;run fsck manually