-
ruoyi(spring-boot)项目 druid 连接池配置多个数据源
为了容易区分,最好把不同数据库的代码放到不同目录下
1.首先修改 application-druid.yml
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 //和druid.yml文件里保持一致 }
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 = DruidDataSourceBuilder.create().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){ ... } }
来源:https://www.cnblogs.com/fengbol/p/15544661.html
最新更新
求1000阶乘的结果末尾有多少个0
详解MyBatis延迟加载是如何实现的
IDEA 控制台中文乱码4种解决方案
SpringBoot中版本兼容性处理的实现示例
Spring的IOC解决程序耦合的实现
详解Spring多数据源如何切换
Java报错:UnsupportedOperationException in Col
使用Spring Batch实现批处理任务的详细教程
java中怎么将多个音频文件拼接合成一个
SpringBoot整合ES多个精确值查询 terms功能实
数据库审计与智能监控:从日志分析到异
SQL Server 中的数据类型隐式转换问题
SQL Server中T-SQL 数据类型转换详解
sqlserver 数据类型转换小实验
SQL Server数据类型转换方法
SQL Server 2017无法连接到服务器的问题解决
SQLServer地址搜索性能优化
Sql Server查询性能优化之不可小觑的书签查
SQL Server数据库的高性能优化经验总结
SQL SERVER性能优化综述(很好的总结,不要错
uniapp/H5 获取手机桌面壁纸 (静态壁纸)
[前端] DNS解析与优化
为什么在js中需要添加addEventListener()?
JS模块化系统
js通过Object.defineProperty() 定义和控制对象
这是目前我见过最好的跨域解决方案!
减少回流与重绘
减少回流与重绘
如何使用KrpanoToolJS在浏览器切图
performance.now() 与 Date.now() 对比