若依RuoYi后台框架配置不同数据库驱动不同数据源
若依RuoYi后台框架配置不同数据库驱动不同数据源
·
目录
需求
项目后台需要用到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用来表示数据源
更多推荐
已为社区贡献3条内容
所有评论(0)