ruoyi(spring-boot)项⽬druid连接池配置多个数据源为了容易区分,最好把不同数据库的代码放到不同⽬录下
1.⾸先修改 l
druid:
# 主库数据源
master:
url: jdbc:mysql://localhost:3306/ry
username: root
password: 123456
# 从库数据源
slave:#名称可以⾃定义,但是要记得代码⾥保持⼀致
enabled: true#这属性不是必须的,但是建议加上,⽅便切换
url: jdbc:mysql://localhost:3306/db
username: root
password: 123456
2.在DataSourceType类添加数据源枚举
public enum DataSourceType
{
MASTER,
SLAVE //和l⽂件⾥保持⼀致
}
3.在DruidConfig配置读取数据源
@Bean
@ConfigurationProperties("spring.datasource.druid.slave")
@ConditionalOnProperty(prefix = "spring.datasource.druid.slave", name = "enabled", havingValue = "true")
public DataSource slaveDataSource(DruidProperties druidProperties)
{
DruidDataSource dataSource = ate().build();
return druidProperties.dataSource(dataSource);
}
4.在DruidConfig类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.SLAVE.name(), "slaveDataSource");
return new DynamicDataSource(masterDataSource, targetDataSources);
}
5.在需要使⽤多数据源⽅法或类上添加@DataSource注解,其中value⽤来表⽰数据源
@Service@DataSource(value = DataSourceType.SLAVE)
public class SysUserServiceImpl{
// 优先级:先⽅法,后类,如果⽅法覆盖了类上的数据源类型,以⽅法的为准,否则以类上的为准
@Service@DataSource(value = DataSourceType.MASTER)
public List<SysUser> selectUserList(SysUser user){
spring怎么读取
}
}

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。