Spring Boot 揭秘与实战(二) 数据存储篇 - 数据访问与多数据源配置
2024-08-25 19:32:52
文章目录
在某些场景下,我们可能会在一个应用中需要依赖和访问多个数据源,例如针对于 MySQL 的分库场景。因此,我们需要配置多个数据源。
环境依赖
修改 POM 文件,添加spring-boot-starter-jdbc依赖。
- <dependency>
- <groupId>org.springframework.boot</groupId>
- <artifactId>spring-boot-starter-jdbc</artifactId>
- </dependency>
添加mysql依赖。
- <dependency>
- <groupId>mysql</groupId>
- <artifactId>mysql-connector-java</artifactId>
- <version>5.1.35</version>
- </dependency>
- <dependency>
- <groupId>com.alibaba</groupId>
- <artifactId>druid</artifactId>
- <version>1.0.14</version>
- </dependency>
数据源
在 src/main/resources/application.properties 中配置数据源信息。
- # mysql
- spring.datasource.one.driver-class-name=com.mysql.jdbc.Driver
- spring.datasource.one.url=jdbc:mysql://localhost:3307/springboot_db1
- spring.datasource.one.username=root
- spring.datasource.one.password=root
- spring.datasource.two.driver-class-name=com.mysql.jdbc.Driver
- spring.datasource.two.url=jdbc:mysql://localhost:3307/springboot_db2
- spring.datasource.two.username=root
- spring.datasource.two.password=root
通过 Java Config 创建 dataSource 和 jdbcTemplate。
我们设定主数据源为 spring.datasource.one 开头的配置,并添加 @Primary ,这样我们还可以享受 Spring Boot 提供的自动配置 DataSource 的机能。此外,第二数据源配置为 spring.datasource.two 开头的配置。
- @Configuration
- @EnableTransactionManagement
- public class BeanConfig {
- @Bean(name = "oneDataSource")
- @Qualifier("oneDataSource")
- @Primary
- @ConfigurationProperties(prefix="spring.datasource.one")
- public DataSource oneDataSource() {
- return DataSourceBuilder.create().build();
- }
- @Bean(name = "twoDataSource")
- @Qualifier("twoDataSource")
- @ConfigurationProperties(prefix="spring.datasource.two")
- public DataSource twoDataSource() {
- return DataSourceBuilder.create().build();
- }
- @Bean(name = "oneJdbcTemplate")
- public JdbcTemplate oneJdbcTemplate(@Qualifier("oneDataSource") DataSource dataSource) {
- return new JdbcTemplate(dataSource);
- }
- @Bean(name = "twoJdbcTemplate")
- public JdbcTemplate twoJdbcTemplate(@Qualifier("twoDataSource") DataSource dataSource) {
- return new JdbcTemplate(dataSource);
- }
- }
单元测试
为了验证我们的配置是否正常,我们通过编写单元测试用例来验证吧。
- @RunWith(SpringJUnit4ClassRunner.class)
- @SpringApplicationConfiguration(WebMain.class)
- public class JdbcTest {
- @Resource(name="oneJdbcTemplate")
- protected JdbcTemplate jdbcTemplate1;
- @Resource(name="twoJdbcTemplate")
- protected JdbcTemplate jdbcTemplate2;
- @Test
- public void test() throws Exception {
- jdbcTemplate1.update("insert into t_author(id, real_name, nick_name) values(?, ?, ?)", 2, "梁桂钊", "LiangGzone");
- jdbcTemplate2.update("insert into t_author(id, real_name, nick_name) values(?, ?, ?)", 2, "梁桂钊", "LiangGzone");
- }
- }
源代码
相关示例完整代码: springboot-action
(完)
如果觉得我的文章对你有帮助,请随意打赏。
- 版权声明:本文由 梁桂钊 发表于 梁桂钊的博客
- 转载声明:自由转载-非商用-非衍生-保持署名(创意共享3.0许可证),非商业转载请注明作者及出处,商业转载请联系作者本人。
- 文章标题:Spring Boot 揭秘与实战(二) 数据存储篇 - 数据访问与多数据源配置
- 文章链接:http://blog.720ui.com/2016/springboot_02_data_datasource/
最新文章
- 关于java多线程
- java历史集合类对比
- Java学习笔记之继承
- innodb b+树
- Java高阶面试问题合集
- 把自己的电脑做服务器发布tomcat的项目外网访问
- 设计模式(8)--Decorator--装饰器模式--结构型
- 201521123052 《Java程序设计》 第12周学习总结
- CentOS7防火墙firewalld设置
- Unity Ulua1.03优化记录
- java数组元素倒置
- VS比较好用的扩展插件总结
- 如何统计TFS代码库中的团队项目所占用的磁盘空间
- Python 数据分析—第九章 数据聚合与分组运算
- char * 与char []探究理解
- 利用git工具命令简单的从github上拷贝和上传代码
- [BZOJ2555]SubString LCT+后缀自动机
- 第19章 	通讯的基本概念—零死角玩转STM32-F429系列
- Codeforces Gym 101775D Mr. Panda and Geometric Sequence(2017-2018 ACM-ICPC Asia East Continent League Final,D题,枚举剪枝)
- 【转载】Hyperledger学习小结