学习笔记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。不同版本可能有所区别。

相关推荐
upper20201 小时前
【炒股学习】集合竞价
学习·区块链
以孝治家行动1 小时前
线上共读传孝道 身体力行润家风——以孝治家家教中心开展线上学习
学习
小智RE0-走在路上2 小时前
Python学习笔记(8) --函数的多返回值,不同传参,匿名函数
笔记·python·学习
摇滚侠3 小时前
Redis 零基础到进阶,Redis 哨兵监控,笔记63-73
数据库·redis·笔记
老王熬夜敲代码3 小时前
网络中数据传输的具体过程
linux·网络·笔记
charlie1145141914 小时前
现代C++嵌入式教程:C++98基础特性:从C到C++的演进(1)
c语言·开发语言·c++·笔记·学习·教程
汤愈韬4 小时前
TK_网络基础和常见攻击(笔记)
网络·笔记
喜欢吃豆4 小时前
我把 LLM 技术栈做成了一张“可复用的认知地图”:notes-on-llms 开源仓库介绍
学习·语言模型·架构·开源·大模型·多模态
学烹饪的小胡桃5 小时前
【运维学习】实时性能监控工具 WGCLOUD v3.6.2 更新介绍
linux·运维·服务器·学习·工单系统
nnsix5 小时前
QFramework学习笔记
笔记·学习