需求

项目后台需要用到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用来表示数据源

Logo

快速构建 Web 应用程序

更多推荐