博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
多数据源配置与使用(1)(三十二)
阅读量:7027 次
发布时间:2019-06-28

本文共 3217 字,大约阅读时间需要 10 分钟。

之前在介绍使用JdbcTemplate和Spring-data-jpa时,都使用了单数据源。在单数据源的情况下,Spring Boot的配置非常简单,只需要在application.properties文件中配置连接参数即可。但是往往随着业务量发展,我们通常会进行数据库拆分或是引入其他数据库,从而我们需要配置多个数据源,下面基于之前的JdbcTemplate和Spring-data-jpa例子分别介绍两种多数据源的配置方式。

多数据源配置

创建一个Spring配置类,定义两个DataSource用来读取application.properties中的不同配置。如下例子中,主数据源配置为spring.datasource.primary开头的配置,第二数据源配置为spring.datasource.secondary开头的配置。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
@Configuration
public 
class 
DataSourceConfig {
 
    
@Bean
(name = 
"primaryDataSource"
)
    
@Qualifier
(
"primaryDataSource"
)
    
@ConfigurationProperties
(prefix=
"spring.datasource.primary"
)
    
public 
DataSource primaryDataSource() {
        
return 
DataSourceBuilder.create().build();
    
}
 
    
@Bean
(name = 
"secondaryDataSource"
)
    
@Qualifier
(
"secondaryDataSource"
)
    
@Primary
    
@ConfigurationProperties
(prefix=
"spring.datasource.secondary"
)
    
public 
DataSource secondaryDataSource() {
        
return 
DataSourceBuilder.create().build();
    
}
 
}
 

对应的application.properties配置如下:

1
2
3
4
5
6
7
8
9
spring.datasource.primary.url=jdbc:mysql:
//localhost:3306/test1
spring.datasource.primary.username=root
spring.datasource.primary.password=root
spring.datasource.primary.driver-
class
-name=com.mysql.jdbc.Driver
 
spring.datasource.secondary.url=jdbc:mysql:
//localhost:3306/test2
spring.datasource.secondary.username=root
spring.datasource.secondary.password=root
spring.datasource.secondary.driver-
class
-name=com.mysql.jdbc.Driver

  

JdbcTemplate支持

对JdbcTemplate的支持比较简单,只需要为其注入对应的datasource即可,如下例子,在创建JdbcTemplate的时候分别注入名为primaryDataSourcesecondaryDataSource的数据源来区分不同的JdbcTemplate。

1
2
3
4
5
6
7
8
9
10
11
@Bean
(name = 
"primaryJdbcTemplate"
)
public 
JdbcTemplate primaryJdbcTemplate(
        
@Qualifier
(
"primaryDataSource"
) DataSource dataSource) {
    
return 
new 
JdbcTemplate(dataSource);
}
 
@Bean
(name = 
"secondaryJdbcTemplate"
)
public 
JdbcTemplate secondaryJdbcTemplate(
        
@Qualifier
(
"secondaryDataSource"
) DataSource dataSource) {
    
return 
new 
JdbcTemplate(dataSource);
}

接下来通过测试用例来演示如何使用这两个针对不同数据源的JdbcTemplate。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
@RunWith
(SpringJUnit4ClassRunner.
class
)
@SpringApplicationConfiguration
(Application.
class
)
public 
class 
ApplicationTests {
 
    
@Autowired
    
@Qualifier
(
"primaryJdbcTemplate"
)
    
protected 
JdbcTemplate jdbcTemplate1;
 
    
@Autowired
    
@Qualifier
(
"secondaryJdbcTemplate"
)
    
protected 
JdbcTemplate jdbcTemplate2;
 
    
@Before
    
public 
void 
setUp() {
        
jdbcTemplate1.update(
"DELETE  FROM  USER "
);
        
jdbcTemplate2.update(
"DELETE  FROM  USER "
);
    
}
 
    
@Test
    
public 
void 
test() 
throws 
Exception {
 
        
// 往第一个数据源中插入两条数据
        
jdbcTemplate1.update(
"insert into user(id,name,age) values(?, ?, ?)"
1
"aaa"
20
);
        
jdbcTemplate1.update(
"insert into user(id,name,age) values(?, ?, ?)"
2
"bbb"
30
);
 
        
// 往第二个数据源中插入一条数据,若插入的是第一个数据源,则会主键冲突报错
        
jdbcTemplate2.update(
"insert into user(id,name,age) values(?, ?, ?)"
1
"aaa"
20
);
 
        
// 查一下第一个数据源中是否有两条数据,验证插入是否成功
        
Assert.assertEquals(
"2"
, jdbcTemplate1.queryForObject(
"select count(1) from user"
, String.
class
));
 
        
// 查一下第一个数据源中是否有两条数据,验证插入是否成功
        
Assert.assertEquals(
"1"
, jdbcTemplate2.queryForObject(
"select count(1) from user"
, String.
class
));
 
    
}
 
 
}

转载于:https://www.cnblogs.com/MaxElephant/p/10239726.html

你可能感兴趣的文章
c# 线程
查看>>
为什么都是a
查看>>
Linux下Gcc生成和使用静态库和动态库详解
查看>>
vim配置及插件安装管理(超级详细)
查看>>
JavaScript 入门
查看>>
基础钢琴弹奏 学习笔记
查看>>
连接新世界
查看>>
Redis Save 与 BGSAVE 的区别
查看>>
Redis 图形化监控方案 RedisLive 介绍
查看>>
python 备份脚本
查看>>
LeetCode - 617. Merge Two Binary Trees
查看>>
splay 1296 营业额统计
查看>>
C#利用System.Net发送邮件(带 抄送、密送、附件、html格式的邮件)
查看>>
.net平台下C#socket通信(中)
查看>>
js实现事件委托
查看>>
大数据开发实战:Stream SQL实时开发三
查看>>
利用POPAnimatableProperty属性来实现动画倒计时
查看>>
hdu Inverting Cups
查看>>
【python】处理xml文件——dom
查看>>
MongoDB启动文件配置参数详解
查看>>