Mybatis配置两个数据源

1.配置两个数据源

# 数据源1配置
datasource1.url=jdbc:oracle:thin:@//your_oracle_host1:your_oracle_port1/your_oracle_sid1
datasource1.username=YourSchema1
datasource1.password=your_password1# 数据源2配置
datasource2.url=jdbc:oracle:thin:@//your_oracle_host2:your_oracle_port2/your_oracle_sid2
datasource2.username=YourSchema2
datasource2.password=your_password2

2.创建两个数据源对象

@Configuration
public class DataSourceConfig {@Primary@Bean(name = "dataSource1")@ConfigurationProperties(prefix = "datasource1")public DataSource dataSource1() {return DataSourceBuilder.create().build();}@Bean(name = "dataSource2")@ConfigurationProperties(prefix = "datasource2")public DataSource dataSource2() {return DataSourceBuilder.create().build();}
}

上面的 @Primary 注解表示 dataSource1 是默认的数据源。你可以根据实际需求来选择是否需要设置默认数据源。 

3.配置 MyBatis SqlSessionFactory 和 MapperScannerConfigurer

在配置 MyBatis 时,你需要配置两个 SqlSessionFactory 对象,每个都使用对应的数据源。

@Configuration
@MapperScan(basePackages = "com.example.mapper1", sqlSessionFactoryRef = "sqlSessionFactory1")
public class MyBatisConfig1 {@Bean(name = "sqlSessionFactory1")public SqlSessionFactory sqlSessionFactory1(@Qualifier("dataSource1") DataSource dataSource) throws Exception {SqlSessionFactoryBean factoryBean = new SqlSessionFactoryBean();factoryBean.setDataSource(dataSource);factoryBean.setMapperLocations(new PathMatchingResourcePatternResolver().getResources("classpath:mapper1/*.xml"));return factoryBean.getObject();}// 可以配置事务管理器等其他属性
}@Configuration
@MapperScan(basePackages = "com.example.mapper2", sqlSessionFactoryRef = "sqlSessionFactory2")
public class MyBatisConfig2 {@Bean(name = "sqlSessionFactory2")public SqlSessionFactory sqlSessionFactory2(@Qualifier("dataSource2") DataSource dataSource) throws Exception {SqlSessionFactoryBean factoryBean = new SqlSessionFactoryBean();factoryBean.setDataSource(dataSource);factoryBean.setMapperLocations(new PathMatchingResourcePatternResolver().getResources("classpath:mapper2/*.xml"));return factoryBean.getObject();}// 可以配置事务管理器等其他属性
}

4. 创建 Mapper 接口和 XML 文件

分别创建两组 Mapper 接口和 XML 文件,每组对应一个数据源。例如,你可以有 com.example.mapper1com.example.mapper2 两个包,分别放置两个数据源的 Mapper 接口和 XML 文件。

5. 在代码中使用

在代码中,你可以根据需要使用不同的 SqlSessionFactory 来获取相应的 SqlSession,从而访问不同的数据库。

@Service
public class YourService {@Autowired@Qualifier("sqlSessionFactory1")private SqlSessionFactory sqlSessionFactory1;@Autowired@Qualifier("sqlSessionFactory2")private SqlSessionFactory sqlSessionFactory2;public void yourMethod() {try (SqlSession sqlSession1 = sqlSessionFactory1.openSession()) {// 使用 sqlSession1 访问数据源1的数据YourMapper1 mapper1 = sqlSession1.getMapper(YourMapper1.class);// ...} catch (Exception e) {// 处理异常}try (SqlSession sqlSession2 = sqlSessionFactory2.openSession()) {// 使用 sqlSession2 访问数据源2的数据YourMapper2 mapper2 = sqlSession2.getMapper(YourMapper2.class);// ...} catch (Exception e) {// 处理异常}}
}

上述代码中,YourMapper1YourMapper2 是分别对应两个数据源的 Mapper 接口,你需要根据实际情况编写这两个接口。通过使用不同的 SqlSessionFactory,你可以分别访问两个不同数据源的数据库。

注:摘自chatgpt

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/629310.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

使用 Python 创造你自己的计算机游戏(游戏编程快速上手)第四版:第十五章到第十八章

十五、反转棋游戏 原文:inventwithpython.com/invent4thed/chapter15.html 译者:飞龙 协议:CC BY-NC-SA 4.0 在本章中,我们将制作反转棋,也称为黑白棋或奥赛罗。这个双人棋盘游戏是在网格上进行的,因此我们…

2024“华数杯”(A题)放射性 Tritium 污染问题国际大学生数学建模竞赛| 建模秘籍文章代码思路大全

铛铛!小秘籍来咯! 小秘籍希望大家都能轻松建模呀,华数杯也会持续给大家放送思路滴~ 抓紧小秘籍,我们出发吧~ 完整内容可以在文章末尾领取! 问题重述: 2024 “Huashu Cup” 国际数学建模大赛 - Proble…

机器学习平台建设(一)

一、概述 下图是较简化的机器学习平台架构,概括了机器学习平台的主要功能和流程。本章会进行简要介绍,在功能章节再展开详述。机器学习最主要的三个步骤可概括为:数据处理、建模以及部署。 数据处理,即所有和数据相关的工作&…

一种基于YOLO改进的高效且轻量级的表面缺陷检测网络, NEU-DET和GC10-DET涨点明显

💡💡💡本文摘要:一种基于YOLO改进的高效且轻量级的表面缺陷检测, 在NEU-DET和GC10-DET任务中涨点明显 目录 1.轻量且高效的YOLO 1.1 SCRB介绍 1.1.1 ScConv介绍 1.2 GSConvns 1.3 od_mobilenetv2_050 1.4 对应ya…

linux多进程基础(6):setitimer(间隔定时器)和signal(信号处理函数)

1.setitimer函数 setitimer函数用于设置一个间隔定时器,它会在指定的时间间隔到达时向进程发送一个信号。其定义如下: #include <sys/time.h> int setitimer(int which, const struct itimerval *new_value, struct itimerval *old_value); 该函数一共有三个参数,其…

什么是ChatGPT,什么是大模型prompt

什么是ChatGpt ChatGPT是一个由美国的OpenAI公司开发的聊天机器人&#xff0c;它使用了大型语言模型&#xff0c;现在有GPT-3、GPT-3.5、GPT-4.0多个版本&#xff0c;目前还在快速发展&#xff0c;通过监督学习和强化学习进行了微调。它可以根据用户的提示执行各种语言任务&am…

【SimPy系列博客之官方example学习与解读】—— Example 3: Car Wash

Hello&#xff0c;CSDN的各位小伙伴们&#xff0c;又见面啦&#xff01;今天我们要学习的例程是&#xff1a;Car Wash&#xff01;我们开始吧&#xff01; 例程背景 这个例程相对于example 2来说会简单一些&#xff0c;有一个洗车厂&#xff0c;里面有若干台洗车机器&#xf…

【Python】P3 循环语句

循环语句 Python 中的通过 for、while 建立循环。 for 循环&#xff1a; 每次循环时&#xff0c;变量会被赋值为迭代对象中的下一个元素&#xff0c;然后执行缩进的代码块。 for i in range(5): # i为变量&#xff0c;range(5)为迭代对象print(i)while循环&#xff1a; 如…

2024年华数杯国际赛A题赛题

问题A&#xff1a;来自日本的放射性废水 背景 2011年3月&#xff0c;日本东海岸发生的地震引发了福岛第一核电站的事故。一场大规模海啸摧毁了该核电站的冷却系统&#xff0c;导致三个核反应堆熔毁&#xff0c;核燃料碎片熔化。为了冷却熔化的核燃料&#xff0c;海水不断地注入…

SQL性能分析手段

SQL执行频率 MySQL 客户端连接成功后&#xff0c;通过 show [session|global] status 命令可以提供整个服务器执行sql的状态信息。通过如下指令&#xff0c;可以查看当前数据库的INSERT、UPDATE、DELETE、SELECT的访问频次&#xff1a; -- session 是查看当前会话 ; -- globa…

uni-app引用矢量库图标

矢量库引用 导入黑色图标 1.生成连接&#xff0c;下载样式 2.导入项目&#xff08;字体样式&#xff09; 3.引入css样式 4.替换font-face 5.使用图标&#xff08;字体图标&#xff0c;只有黑色&#xff09; 导入彩色图标 1.安装插件 npm install -g iconfont-tools2.…

IDEA 在本地启动多个 SpringBoot 后端服务模拟集群

目录 方式一&#xff1a;使用 IDEA 界面在多个后端端口运行同一个项目 方式二&#xff1a;通过控制台在运行项目 jar 包时传入端口配置 方式一&#xff1a;使用 IDEA 界面在多个后端端口运行同一个项目 1. 点击 Run / Debug 在默认端口启动项目 2. 点击 Services&#xff0…

【CSDN博客系列】自定义模块

&#x1f49d;&#x1f49d;&#x1f49d;欢迎来到我的博客&#xff0c;很高兴能够在这里和您见面&#xff01;希望您在这里可以感受到一份轻松愉快的氛围&#xff0c;不仅可以获得有趣的内容和知识&#xff0c;也可以畅所欲言、分享您的想法和见解。 推荐:kwan 的首页,持续学…

学习k8s的应用(三)

一、k8s部署ngnix 1、一些查看命令 1-1、所有命令空间 kubectl get pod --all-namespaces kubectl get svc --all-namespaces1-2、指定命令空间 kubectl get pod -n yabin kubectl get svc -n yabin2、单节点集群兼容 # 因为目前只有一个master节点&#xff0c;默认安装后…

LVI-SAM室外环境测试

LVI-SAM室外环境测试 昨天在室外进行了远程控制实验&#xff0c;整体上还是比较流畅的&#xff0c;顺带录制了 bag 包 本来应当是顺带录制 GPS 信息的&#xff0c;但是 bag 包里没有&#xff0c;不然还想试一下点云投影来着 同样的 YAML 配置&#xff0c;在室内环境中能够成…

设计Twitter时间线和搜索功能

设计Twitter时间线和搜索功能 设计 facebook feed 和 设计 facebook search是相同的问题 第一步&#xff1a;定义用例和约束 定义问题的需求和范围&#xff0c;询问问题去声明用例和约束&#xff0c;讨论假设 ps: 没有一个面试官会展示详细的问题&#xff0c;我们需要定义一些用…

数据结构与算法-二叉树-层次遍历I

二叉树层次遍历I 给你二叉树的根节点 root &#xff0c;返回其节点值的 层序遍历 。 &#xff08;即逐层地&#xff0c;从左到右访问所有节点&#xff09;。 示例 1&#xff1a; 输入&#xff1a;root [3,9,20,null,null,15,7] 输出&#xff1a;[[3],[9,20],[15,7]]思路&…

【征服redis1】基础数据类型详解和应用案例

博客计划 &#xff0c;我们从redis开始&#xff0c;主要是因为这一块内容的重要性不亚于数据库&#xff0c;但是很多人往往对redis的问题感到陌生&#xff0c;所以我们先来研究一下。 本篇&#xff0c;我们先看一下redis的基础数据类型详解和应用案例。 1.redis概述 以mysql为…

TypeScript基础知识:高级数据类型

TypeScript 是一种静态类型检查的 JavaScript 超集&#xff0c;它提供了许多强大的高级数据类型&#xff0c;可以帮助我们更好地定义和操作数据。本文将深入介绍 TypeScript 的高级数据类型&#xff0c;包括交叉类型、联合类型和映射类型&#xff0c;并通过示例代码演示它们的用…

【C/C++】C语言的高级编程(内存分区,指针)

C语言的高级编程【内存&#xff0c;指针】 基本知识变量gcc size工具 内存分区指针相关定义和赋值指针加法函数指针多级指针数组指针传参 基本知识 变量 变量解释全局变量出现在代码块{}之外的变量就是全局变量局部变量一般情况下&#xff0c;代码块{}内部定义的变量就是自动…