若依RuoYi后台框架配置不同数据库驱动不同数据源

23 篇文章 1 订阅
4 篇文章 0 订阅

需求

项目后台需要用到MYSQL 与 PostgreSQL,所以需要配置多源数据库,而且两种数据库驱动不一致

一、参考若依官网文档

参考官网
根据官网对多元数据库配置的说明进行配置修改

二、具体配置

1.在application-druid.yml配置从库数据源

代码如下:

datasource:
    type: com.alibaba.druid.pool.DruidDataSource
    druid:
        # 主库数据源
        master:
            url: jdbc:mysql://19.19.3.15:336/basic?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8
            username: xx
            password: Xx
# 从库数据源
        slave4:
            # 从数据源开关/默认关闭
            enabled: true
            url: jdbc:postgresql://19.24.112.29:1111/jszd?useUnicode=true&characterEncoding=utf8
            username: xx
            password: yy

注意要去掉diverClassName配置:
在这里插入图片描述
在这里插入图片描述

2.在DataSourceType类添加数据源枚举

代码如下:

package com.ruoyi.framework.aspectj.lang.enums;

/**
 * 数据源
 * 
 * @author ruoyi
 */
public enum DataSourceType
{
    /**
     * 主库
     */
    MASTER,
    /**
     * 从库
     */
    SLAVE4
}

3.在DruidConfig配置读取数据源,在DruidConfig类dataSource方法添加数据源

代码如下:

@Bean
@ConfigurationProperties("spring.datasource.druid.slave4")
@ConditionalOnProperty(prefix = "spring.datasource.druid.slave4", name = "enabled", havingValue = "true")
public DataSource slave4DataSource(DruidProperties druidProperties)
{
	DruidDataSource dataSource = DruidDataSourceBuilder.create().build();
	return druidProperties.dataSource(dataSource);
}


@Bean(name = "dynamicDataSource")
@Primary
public DynamicDataSource dataSource(DataSource masterDataSource)
{
    Map<Object, Object> targetDataSources = new HashMap<>();
    targetDataSources.put(DataSourceType.MASTER.name(), masterDataSource);
    setDataSource(targetDataSources, DataSourceType.SLAVE4.name(), "slave4DataSource");
    return new DynamicDataSource(masterDataSource, targetDataSources);
}

在需要使用多数据源方法或类上添加@DataSource注解,其中value用来表示数据源

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值