学习笔记067——若依前后端分离版本如何设置主从库

文章目录

1、需求背景

项目有时会需要同时访问到两个不同的数据库,来实现数据的处理。

2、实现方式

例如本人需要主库是:MySQL,

从库是Oracle。

2.1、依赖导入

先在maven依赖中导入Oracle驱动(驱动版本根据自己的Oracle版本来定)

xml 复制代码
<dependency>
    <groupId>com.oracle.database.jdbc</groupId>
    <artifactId>ojdbc8</artifactId>
    <version>19.3.0.0</version>
</dependency>

2.2、数据源配置

然后在项目的 application-druid.yml 文件中开启slave.enable: true

并且分别设置好主从库数据源信息。

2.3、使用

在Service实现类的类上 / 方法上

或者mapper的类上 / 方法上

添加:

java 复制代码
@DataSource(value = DataSourceType.SLAVE)

点击注解中SLAVE可以看到,MASTER表示主库,SLAVE表示从库。

默认加注解时,使用的是主库。

java 复制代码
/**
 * 数据源
 * 
 * @author ruoyi
 */
public enum DataSourceType
{
    /**
     * 主库
     */
    MASTER,

    /**
     * 从库
     */
    SLAVE
}

举例子:

注解加在类上,表明该类下的所有方法都是访问从库。

如果注解加在某个方法上,表明该方法访问的是从库。

mapper同理。

PS:本人使用若依版本是3.6.0。不同版本可能有所区别。

相关推荐
fake_ss1985 小时前
AI时代学习全栈项目开发的新范式
java·人工智能·学习·架构·个人开发·学习方法
Upsy-Daisy6 小时前
AI Agent 项目学习笔记(二):Spring AI 与 ChatClient 主链路解析
人工智能·笔记·学习
C+++Python7 小时前
C++ 进阶学习完整指南
java·c++·学习
杨浦老苏7 小时前
AI原生笔记应用Tolaria
笔记·ai·markdown·obsidian
中屹指纹浏览器8 小时前
浏览器网络栈隔离技术研究:TCP/IP底层指纹生成与规避原理
经验分享·笔记
sulikey8 小时前
个人Linux操作系统学习笔记2 - gcc与库的理解
linux·笔记·学习·操作系统·gcc·
南浦别a8 小时前
第102天--时隔多日的书写
学习·程序人生
Jackyzhe8 小时前
从零学习Kafka:消费者组重平衡
分布式·学习·kafka
吃好睡好便好9 小时前
在Creo中如何把新建零件文件时的默认模板设置为公制单位
学习·3d·信息可视化
优橙教育9 小时前
5G网络优化关键参数解读:从入门到实战
网络·学习·5g