需求

项目后台需要用到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 应用程序

更多推荐