java 项目实现多数据源

pring:
	datasource:
		db1:
			url: jdbc:mysql://localhost:3306/db1
			username: root
			password: root
		db2:
			url: jdbc:mysql://localhost:3306/db2
			username: root
			password: root
/**
 * @Description: 数据源枚举
 * @Author: yy
 * @CreateTime: 2023-04-26 14:47
 */
public enum DatabaseType {
   db1, db2;}
/**
 * @Description: 配置数据源Bean
 * @Author: yy
 * @CreateTime: 2023-04-26 14:47
 */
@Configuration
@MapperScan(basePackages = {
   "com.example.mapper"})
public class DataSourceConfig {
   

    @Bean(name = "dataSource1")
    @ConfigurationProperties(prefix = "spring.datasource.db1")
    public DataSource dataSource1() {
   
        return DataSourceBuilder.create().build();
    }

    @Bean(name = 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java项目实现多数据源实例可以采用以下步骤: 1. 配置多个数据源连接信息,可以在项目的配置文件中添加多个数据源的连接信息,例如:application.yml ``` # 主数据源配置 spring: datasource: url: jdbc:mysql://localhost:3306/db1 username: root password: root driver-class-name: com.mysql.jdbc.Driver # 第二数据源配置 second: datasource: url: jdbc:mysql://localhost:3306/db2 username: root password: root driver-class-name: com.mysql.jdbc.Driver ``` 2. 配置数据源的实例化,可以通过编写配置类来实现多数据源的实例化,例如: ``` @Configuration public class DataSourceConfig { @Bean(name = "primaryDataSource") @Primary @ConfigurationProperties(prefix = "spring.datasource") public DataSource primaryDataSource() { return DataSourceBuilder.create().build(); } @Bean(name = "secondDataSource") @ConfigurationProperties(prefix = "second.datasource") public DataSource secondDataSource() { return DataSourceBuilder.create().build(); } } ``` 3. 配置多数据源的JdbcTemplate实例,可以通过JdbcTemplate来操作多个数据源,例如: ``` @Configuration public class JdbcTemplateConfig { @Bean(name = "primaryJdbcTemplate") public JdbcTemplate primaryJdbcTemplate(@Qualifier("primaryDataSource") DataSource dataSource) { return new JdbcTemplate(dataSource); } @Bean(name = "secondJdbcTemplate") public JdbcTemplate secondJdbcTemplate(@Qualifier("secondDataSource") DataSource dataSource) { return new JdbcTemplate(dataSource); } } ``` 4. 在需要使用多数据源的地方注入对应的JdbcTemplate实例,例如: ``` @Service public class UserServiceImpl implements UserService { @Autowired @Qualifier("primaryJdbcTemplate") private JdbcTemplate primaryJdbcTemplate; @Autowired @Qualifier("secondJdbcTemplate") private JdbcTemplate secondJdbcTemplate; @Override public List<User> getUserList() { String sql = "SELECT * FROM user"; List<User> userList = primaryJdbcTemplate.query(sql, new BeanPropertyRowMapper<>(User.class)); String sql2 = "SELECT * FROM user2"; List<User> userList2 = secondJdbcTemplate.query(sql2, new BeanPropertyRowMapper<>(User.class)); userList.addAll(userList2); return userList; } } ``` 以上就是Java项目实现多数据源实例的基本步骤,可以根据实际需求进行修改和优化。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值