為了容易區分,最好把不同資料庫的代碼放到不同目錄下
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 = "https://www.cnblogs.com/fengbol/p/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 =https://www.cnblogs.com/fengbol/p/ DataSourceType.SLAVE) public class SysUserServiceImpl{ // 優先級:先方法,后類,如果方法覆寫了類上的資料源型別,以方法的為準,否則以類上的為準 @Service@DataSource(value =https://www.cnblogs.com/fengbol/p/ DataSourceType.MASTER) public List<SysUser> selectUserList(SysUser user){ ... } }
轉載請註明出處,本文鏈接:https://www.uj5u.com/houduan/356642.html
標籤:Java
